

***Rockchip***  
***RK3326***  
***Technical Reference Manual***  
***Part2***

Revision 1.0  
June. 2018

## **Revision History**

| <b>Date</b> | <b>Revision</b> | <b>Description</b> |
|-------------|-----------------|--------------------|
| 2018-6-11   | 1.0             | Initial release    |

## Table of Content

|                                                            |     |
|------------------------------------------------------------|-----|
| Table of Content.....                                      | 3   |
| Figure Index .....                                         | 5   |
| Table Index .....                                          | 7   |
| Warranty Disclaimer .....                                  | 9   |
| Chapter 1 Interconnect .....                               | 10  |
| 1.1 Overview .....                                         | 10  |
| 1.2 Block Diagram .....                                    | 10  |
| 1.3 Function Description.....                              | 10  |
| 1.4 Register Description .....                             | 14  |
| 1.5 Application Notes .....                                | 33  |
| Chapter 2 Dynamic Memory Interface ( DMC ).....            | 35  |
| 2.1 Overview .....                                         | 35  |
| 2.2 Block Diagram .....                                    | 35  |
| 2.3 Function Description.....                              | 36  |
| 2.4 Register Description .....                             | 36  |
| 2.5 Interface Description .....                            | 169 |
| 2.6 Application Notes .....                                | 170 |
| Chapter 3 Mobile Storage Host Controller.....              | 177 |
| 3.1 Overview .....                                         | 177 |
| 3.2 Block Diagram .....                                    | 177 |
| 3.3 Function Description.....                              | 178 |
| 3.4 Register Description .....                             | 198 |
| 3.5 Interface Description .....                            | 225 |
| 3.6 Application Notes .....                                | 226 |
| Chapter 4 Process-Voltage-Temperature Monitor (PVTM) ..... | 248 |
| 4.1 Overview .....                                         | 248 |
| 4.2 Block Diagram .....                                    | 248 |
| 4.3 Function Description.....                              | 248 |
| 4.4 Application Notes .....                                | 249 |
| Chapter 5 Multi-format Video Encoder And Decoder.....      | 250 |
| 5.1 Overview .....                                         | 250 |
| 5.2 Block Diagram .....                                    | 251 |
| 5.3 Function Description.....                              | 252 |
| 5.4 Register Description .....                             | 257 |
| 5.5 Application Notes .....                                | 382 |
| Chapter 6 Video Input Processor (VIP) .....                | 385 |
| 6.1 Overview .....                                         | 385 |
| 6.2 Block Diagram .....                                    | 385 |
| 6.3 Function Description.....                              | 385 |
| 6.4 Register Description .....                             | 387 |
| 6.5 Interface Description .....                            | 398 |
| 6.6 Application Notes .....                                | 399 |
| Chapter 7 Video Output Processor (VOP_BIG) .....           | 400 |
| 7.1 Overview .....                                         | 400 |
| 7.2 Block Diagram .....                                    | 401 |
| 7.3 Function Description.....                              | 401 |
| 7.5 Timing Diagram .....                                   | 458 |

|                                                  |     |
|--------------------------------------------------|-----|
| 7.6 Interface Description .....                  | 459 |
| 7.7 Application Notes .....                      | 460 |
| Chapter 8 Raster Graphic Acceleration(RGA) ..... | 464 |
| 8.1 Overview .....                               | 464 |
| 8.2 Block Diagram .....                          | 465 |
| 8.3 Function Description .....                   | 466 |
| 8.5 Application Notes .....                      | 494 |
| Chapter 9 Crypto.....                            | 497 |
| 9.1 Overview .....                               | 497 |
| 9.2 Block Diagram .....                          | 497 |
| 9.3 Register description .....                   | 498 |
| 9.4 Application Note .....                       | 533 |
| Chapter 10 USB OTG2.0 .....                      | 540 |
| 10.1 Overview.....                               | 540 |
| 10.2 Block Diagram .....                         | 540 |
| 10.3 USB OTG 2.0 Controller.....                 | 540 |
| 10.4 USB OTG 2.0 PHY .....                       | 540 |
| 10.5 UART BYPASS FUNCITON.....                   | 541 |
| 10.6 Register Description.....                   | 541 |
| 10.7 Interface description .....                 | 651 |
| 10.8 Application Note .....                      | 651 |
| Chapter 11 USB2.0 Host.....                      | 652 |
| 11.1 Overview.....                               | 652 |
| 11.2 Block Diagram .....                         | 652 |
| 11.3 Function Description .....                  | 652 |
| 11.4 Register Description.....                   | 653 |
| 11.5 Interface Description .....                 | 653 |
| 11.6 Application Notes .....                     | 653 |
| Chapter 12 MIPI DSI HOST Controller .....        | 654 |
| 12.1 Overview.....                               | 654 |
| 12.2 Block Diagram .....                         | 654 |
| 12.3 Function Description .....                  | 655 |
| 12.4 Register Description.....                   | 662 |
| Chapter 13 MIPI DSI D-PHY .....                  | 709 |
| 13.1 Overview.....                               | 709 |
| 13.2 Block Diagram .....                         | 709 |
| 13.3 Function Description .....                  | 710 |
| 13.4 Register Description.....                   | 712 |
| 13.5 Application Notes .....                     | 721 |
| Chapter 14 MIPI CSI D-PHY .....                  | 723 |
| 14.1 Overview.....                               | 723 |
| 14.2 Block Diagram .....                         | 723 |
| 14.3 Function Description .....                  | 723 |
| 14.4 Register Description.....                   | 725 |
| 14.5 Application Notes .....                     | 727 |

## Figure Index

|                                                                          |     |
|--------------------------------------------------------------------------|-----|
| Fig. 1-1 Interconnect diagram .....                                      | 10  |
| Fig. 1-2 Idle request .....                                              | 34  |
| Fig. 3-1 Host Controller Block Diagram .....                             | 178 |
| Fig. 3-2 SD/MMC Card-Detect Signal .....                                 | 182 |
| Fig. 3-3 Host Controller Command Path State Machine .....                | 184 |
| Fig. 3-4 Host Controller Data Transmit State Machine .....               | 186 |
| Fig. 3-5 Host Controller Data Receive State Machine .....                | 188 |
| Fig. 3-6 Dual-Buffer Descriptor Structure .....                          | 194 |
| Fig. 3-7 Chain Descriptor Structure .....                                | 194 |
| Fig. 3-8 Descriptor Formats for 32-bit AHB Address Bus Width .....       | 194 |
| Fig. 3-9 SD/MMC Card-Detect and Write-Protect .....                      | 226 |
| Fig. 3-10 SD/MMC Card Termination .....                                  | 227 |
| Fig. 3-11 Host Controller Initialization Sequence .....                  | 229 |
| Fig. 3-12 Voltage Switching Command Flow Diagram .....                   | 238 |
| Fig. 3-13 ACMD41 Argument .....                                          | 238 |
| Fig. 3-14 ACMD41 Response(R3) .....                                      | 239 |
| Fig. 3-15 Voltage Switch Normal Scenario .....                           | 239 |
| Fig. 3-16 Voltage Switch Error Scenario .....                            | 240 |
| Fig. 3-17 CASES for eMMC 4.5 START bit .....                             | 242 |
| Fig. 3-18 Clock Generation Unit .....                                    | 244 |
| Fig. 3-19 Card Detection Method 2 .....                                  | 246 |
| Fig. 3-20 Card Detection Method 4 .....                                  | 247 |
| Fig. 4-1 PVTM Block Diagram .....                                        | 248 |
| Fig. 5-1 VPU Combo in SOC .....                                          | 251 |
| Fig. 5-2 VPU Combo Block Diagram .....                                   | 251 |
| Fig. 5-3 structure of two-level page table .....                         | 255 |
| Fig. 5-4 Dataflow of HW performs entropy decoding in video decoder ..... | 256 |
| Fig. 5-5 Dataflow of SW performs entropy decoding in video decoder ..... | 256 |
| Fig. 5-6 HEVC Common Configuration Flow .....                            | 384 |
| Fig. 6-1 VIP block diagram .....                                         | 385 |
| Fig. 6-2 Timing diagram for VIP when vsync low active .....              | 386 |
| Fig. 6-3 Timing diagram for VIP when vsync high active .....             | 386 |
| Fig. 6-4 Timing diagram for VIP when href high active .....              | 386 |
| Fig. 6-5 Timing diagram for VIP when href low active .....               | 386 |
| Fig. 6-6 Timing diagram for VIP when Y data first .....                  | 386 |
| Fig. 6-7 Timing diagram for VIP when U data first .....                  | 386 |
| Fig. 6-8 CCIR656 timing .....                                            | 387 |
| Fig. 6-9 Raw Data or JPEG Timing .....                                   | 387 |
| Fig. 7-1 VOP Block Diagram .....                                         | 401 |
| Fig. 7-2 VOP Frame Buffer Data Format .....                              | 401 |
| Fig. 7-3 VOP HWC Palette (8bpp) .....                                    | 402 |
| Fig. 7-4 VOP Internal DMA .....                                          | 402 |
| Fig. 7-5 VOP Virtual Display Mode .....                                  | 403 |
| Fig. 7-6 VOP Scaling Down Offset .....                                   | 403 |
| Fig. 7-7 VOP Scaling Up Offset .....                                     | 404 |
| Fig. 7-8 VOP Overlay Display .....                                       | 404 |
| Fig. 7-9 VOP Transparency Color Key .....                                | 405 |
| Fig. 7-10 VOP Alpha blending .....                                       | 405 |
| Fig. 7-11 VOP BCSH Diagram .....                                         | 406 |
| Fig. 7-12 VOP Gamma LUTs .....                                           | 406 |
| Fig. 7-13 VOP Replication .....                                          | 407 |
| Fig. 7-14 vop dithering .....                                            | 407 |
| Fig. 7-15 Limitations of multi-region display of win2 .....              | 408 |
| Fig. 7-16 Correct application of multi-region display of win2 .....      | 408 |
| Fig. 7-17 VOP RGB interface timing setting .....                         | 458 |

|                                                                   |     |
|-------------------------------------------------------------------|-----|
| Fig. 7-18 VOP RGB Interface Timing(SDR) .....                     | 459 |
| Fig. 7-19 VOP Display output for peripherals .....                | 460 |
| Fig. 7-20 VOP RGB Mode Programming Flow .....                     | 462 |
| Fig. 8-1 RGA Block Diagram.....                                   | 465 |
| Fig. 8-2 RGA2 in SOC.....                                         | 465 |
| Fig. 8-3 RGA Input Data Format .....                              | 466 |
| Fig. 8-4 RGA Dither effect.....                                   | 467 |
| Fig. 8-5 layer0 alpha blending calculate flow .....               | 468 |
| Fig. 8-6 layer1 alpha blending calculate flow .....               | 469 |
| Fig. 8-7 RGA Gradient Fill .....                                  | 469 |
| Fig. 8-8 RGAsoftware main register-region.....                    | 494 |
| Fig. 8-9 RGA command line and command counter.....                | 495 |
| Fig. 8-10 RGA command sync generation.....                        | 495 |
| Fig. 8-11 the size constraint among A B C.....                    | 495 |
| Fig. 9-1 Crypto Architecture.....                                 | 497 |
| Fig. 9-2 LLI DMA Usage.....                                       | 535 |
| Fig. 9-3 AES-HASH-RX mode .....                                   | 538 |
| Fig. 9-4 AES-HASH-TX mode.....                                    | 539 |
| Fig. 11-1 USB2.0 Host Controller Block Diagram .....              | 652 |
| Fig. 12-1 MIPI DSI HOST Controller architecture .....             | 655 |
| Fig. 12-2 24bpp APB Pixel to Byte Organization .....              | 658 |
| Fig. 12-3 18 bpp APB Pixel to Byte Organization .....             | 658 |
| Fig. 12-4 16 bpp APB Pixel to Byte Organization .....             | 658 |
| Fig. 12-5 12 bpp APB Pixel to Byte Organization .....             | 659 |
| Fig. 12-6 8bpp APB Pixel to Byte Organization .....               | 659 |
| Fig. 12-7 Command Transmission Periods within the Image Area..... | 659 |
| Fig. 12-8 Location in the Image Area.....                         | 661 |
| Fig. 13-1 MIPI DSI D-PHY detailed block diagram.....              | 709 |
| Fig. 13-2 MIPI DSI D-PHY and VOP connection .....                 | 710 |
| Fig. 13-3 LVDS mode clock timing.....                             | 712 |
| Fig. 13-4 LVDS mode lsb parallel data to serial data timing ..... | 712 |
| Fig. 14-1 MIPI CSI D-PHY detailed block diagram.....              | 723 |
| Fig. 14-2 MIPI CSI D-PHY and ISP connection.....                  | 724 |

## Table Index

|                                                                         |     |
|-------------------------------------------------------------------------|-----|
| Table 1-1 QoS Generator .....                                           | 11  |
| Table 1-2 'ddrconf' item.....                                           | 12  |
| Table 1-3 Probe.....                                                    | 13  |
| Table 2-1 DDR IO description .....                                      | 169 |
| Table 2-2 DDR4 IO Mapping Table.....                                    | 169 |
| Table 2-3 DDR PHY TX DLLs Delay Step .....                              | 172 |
| Table 2-4 DDR PHY RX DQS Delay Step .....                               | 172 |
| Table 2-5 CK/CMD Driver output resistance .....                         | 173 |
| Table 2-6 DM, DQ Signal Drive Strength Register .....                   | 173 |
| Table 2-7 DDR3 1.5V DQ/DQS/CMD Driver and ODT resistance .....          | 174 |
| Table 2-8 DDR4/LPDDR2/3 1.2V DQ/DQS/CMD driver and ODT resistance ..... | 174 |
| Table 2-9 Low Power DLL Setting .....                                   | 174 |
| Table 2-10 per-bit de-skew tuning resolution .....                      | 175 |
| Table 3-1 Bits in Interrupt Status Register.....                        | 180 |
| Table 3-2 Auto-Stop Generation.....                                     | 189 |
| Table 3-3 Non-data Transfer Commands and Requirements .....             | 190 |
| Table 3-4 Bits in IDMAC DES0 Element .....                              | 194 |
| Table 3-5 Bits in IDMAC DES1 Element .....                              | 195 |
| Table 3-6 Bits in IDMAC DES2 Element .....                              | 196 |
| Table 3-7 Bits in IDMAC DES3 Element .....                              | 196 |
| Table 3-8 SDMMC Interface Description .....                             | 225 |
| Table 3-9 SDIO Interface Description .....                              | 225 |
| Table 3-10 EMMC Interface Description.....                              | 226 |
| Table 3-11 Recommended Usage of use_hold_reg .....                      | 228 |
| Table 3-12 Command Settings for No-Data Command.....                    | 231 |
| Table 3-13 Command Setting for Single or Multiple-Block Read .....      | 233 |
| Table 3-14 Command Settings for Single or Multiple-Block Write .....    | 234 |
| Table 3-15 PBL and Watermark Levels .....                               | 243 |
| Table 3-16 Configuration for SDMMC Clock Generation.....                | 244 |
| Table 3-17 Configuration for SDIO Clock Generation .....                | 244 |
| Table 3-18 Configuration for EMMC Clock Generation .....                | 245 |
| Table 3-19 Register for SDMMC Card Detection Method 3 .....             | 247 |
| Table 4-1 core_pvtm control source and result destination .....         | 248 |
| Table 4-2 pmu_pvtm control source and result destination .....          | 249 |
| Table 7-1 VOP Data Swap of Win0 and Win1.....                           | 402 |
| Table 7-2 VOP Scaling Start Point Offset Registers.....                 | 404 |
| Table 7-3 VOP Control Pins Definition .....                             | 459 |
| Table 7-4 Gather configuration for all format .....                     | 460 |
| Table 7-5 effective immediately register table .....                    | 462 |
| Table 8-1 RGAROP Boolean operations.....                                | 470 |
| Table 9-1 Crypto Clock & Reset Description .....                        | 533 |
| Table 9-2 Crypto Clock & Reset Description .....                        | 534 |
| Table 9-3 Crypto Performance Description.....                           | 534 |
| Table 9-4 LLI Item Description .....                                    | 535 |
| Table 9-5 LLI Item dma_ctl Description .....                            | 535 |
| Table 9-6 LLI Item user_define Description .....                        | 536 |
| Table 9-7 LLI Item user_define Description .....                        | 536 |
| Table 9-8 LLI Item user_define Description .....                        | 537 |
| Table 10-1USB OTG 2.0 Interface Description .....                       | 651 |
| Table 11-1 USB2.0 Host Controller Address Mapping.....                  | 653 |
| Table 11-2 USB2.0 PHY Interface Description .....                       | 653 |
| Table 12-1 Color table.....                                             | 656 |
| Table 13-1 function of grf bits in MIPI mode .....                      | 710 |
| Table 13-2 LVDS map setting .....                                       | 711 |
| Table 13-3 TTL mapping of digital signals to analog pads.....           | 712 |

|                                                           |     |
|-----------------------------------------------------------|-----|
| Table 14-1 function of grf bits in MIPI mode .....        | 724 |
| Table 14-2 registers address for 5 lanes table.....       | 725 |
| Table 14-3 registers configuration for 5 lanes table..... | 725 |

## **Warranty Disclaimer**

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

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

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

### **Copyright and Patent Right**

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

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

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

### **Trademarks**

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

### **Confidentiality**

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

### **Reverse engineering or disassembly is prohibited.**

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

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

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

# Chapter 1 Interconnect

## 1.1 Overview

The chip-level interconnect consists of main interconnect. It enables communication among the modules and subsystems in the device.

The main interconnect supports the following features:

- Cross-bar exchange network
- A special internal slave for accessing the configuration register
- Little-endian platform
- Embedded memory scheduler for DDR transaction generation
- QoS management for optimizing the transaction flow
- Transaction statistics for analyzing the transaction flow
- Security protection mechanism to compatible with the TrustZone technology

## 1.2 Block Diagram



Fig. 1-1 Interconnect diagram

## 1.3 Function Description

### 1.3.1 QoS management

The main interconnect is connected with all the related IPs of the system, the interface between the IP and the interconnect is called as NIU(native interface unit).

The interconnect offers 4 modes of qos management:

- None, QoSGenerator is disabled, and priority information are stuck at 0.
- Fixed, QoSGenerator drives apply a fixed urgency to read transactions, and a (possibly different) urgency to write transactions.
- Limiter, QoSGenerator behaves as in fixed mode, but limits the traffic bandwidth coming from that socket, possibly stalling requests if the initiator attempts to exceed its budget.
- Regulator, QoSGenerator promotes are demotes hurry, depending the bandwidth obtained by the initiator is below or beyond a bandwidth budget. As transactions exceeding the bandwidth limit are sent (even though demoted), the regulator mode may be considered as a softer version of the limiter mode.

#### Limiter Behavior

When configured in bandwidth limiter, the unit uses a 23 bit counter to measure the average bandwidth. This counter has a 1/256 byte resolution and works as follows:

- Adds the number of byte rounded up to 16 (1 -> 16) and then multiplied by 256 to the current value, each time a request is sent.
- Subtracts the Bandwidth register value every cycle. If the Counter becomes negative, force it to 0.
- If the Counter value is greater than the Saturation register value multiplied by 16\*256, any incoming request is stalled until this condition disappears. Note that the Counter cannot wrap-around because the maximum value it can reach is: SaturationMax\*16\*256 + BurstMax\*256 = 1023\*4K+4K\*256 = 5116K or 223 = 8192K.

The following example will show the Counter behavior: 32 byte bursts, F=400MHz, BW=200MB/s, T=0.32us. The Bandwidth register will be set to  $256*200/400 = 128$ , and the Saturation register to  $128*0.32*400/4096 = 4$  (which corresponds to 64 bytes).

### Regulator Behavior

When configured in bandwidth regulator, the unit uses a 23 bit counter to measure the average bandwidth. This counter has a 1/256 byte resolution and works as follows:

- Adds the number of byte rounded up to 16 and then multiplied by 256 to the current value, each time a response is received. If the result is greater than the Saturation register value multiplied by  $16*256$ , saturation to this value is applied.
- Subtracts the Bandwidth register value every cycle. If the Counter becomes negative, force it to 0.
- If the Counter value is less than or equal to the Saturation register value multiplied by  $16*256/2$ , the SocketMst Hurry signal will be set to the HurryHigh register, and HurryLow otherwise. Note that Urgency and Press will be also set to the same value.

The following example will show the Counter behavior: 1Kbyte bursts, F=500MHz, BW=2GB/s, T=2.048us. The Bandwidth register will be set to  $256*2000/500 = 1024$ , and the Saturation register to  $1024*2.048*500/4096 = 256$  (which corresponds to 4 Kbytes).

### QoS Generator Programming

**Bandwidth:** This  $\log_2(\text{socket.wData}/8)+8$  bits register defines the bandwidth in 1/256th byte per cycle unit. This allows a 2 MByte/s resolution at 500MHz. When the bandwidth is given in MByte/s, the value of this register will be equal to  $256*\text{BWMB/s} / \text{FMHz}$ .

**Saturation:** This 10 bits register defines the number of byte used for bandwidth measurement. It is expressed in 16bytes unit (up to 16 Kbyte). Usually the integration window is given in us or in cycle: the value of this register will be equal to  $\text{Bandwidth} * \text{Tus} * \text{FMHz} / (256*16)$  or  $\text{Bandwidth} * \text{Ncycle} / (256*16)$ .

The QoS management for peri-interconnect and main-interconnect inside each interconnect is independent. When master in peri-interconnect access main-interconnect, the QoS will be propagated to main-interconnect according to QoS configuration for 'perilpslv\_nsp' (perilp master, cci\_m0 and debug access slave register), 'perilp\_nsp' (perilp master, cci\_m0 and debug access data memory) and 'perihp\_nsp' (perihp master access data memory). The masters in main-interconnect does not access peri-interconnect.

The default setting of master NIUs are listing below:

Table 1-1 QoS Generator

| Master NIU | Priority0/1 | Register Base Address |
|------------|-------------|-----------------------|
| cpu        | 2           | 0xff508000            |
| gpu        | 1           | 0xff520000            |
| isp_128m   | 3           | 0xff548000            |
| isp_rd_m   | 3           | 0xff548080            |
| isp_wr_m   | 3           | 0xff548100            |
| isp_m1     | 3           | 0xff548180            |
| vip_m      | 3           | 0xff548200            |
| rga_rd_m   | 1           | 0xff550000            |
| rga_wr_m   | 1           | 0xff550080            |
| vop_m0     | 3           | 0xff550100            |
| vop_m1     | 3           | 0xff550180            |
| vpu_m      | 2           | 0xff558000            |
| vpu_r128   | 2           | 0xff558080            |
| dcf        | 1           | 0xff500000            |
| dmac       | 1           | 0xff500080            |
| crypto     | 1           | 0xff510000            |
| gmac       | 1           | 0xff518000            |
| emmc       | 1           | 0xff538000            |
| nand       | 1           | 0xff538080            |
| sdio       | 1           | 0xff538100            |
| sfc        | 1           | 0xff538180            |

| <b>Master NIU</b> | <b>Priority0/1</b> | <b>Register Base Address</b> |
|-------------------|--------------------|------------------------------|
| sdmmc             | 1                  | 0xff52c000                   |
| usb_host          | 1                  | 0xff540000                   |
| usb_otg           | 1                  | 0xff540080                   |

Note:

- All master NIU QoS generator mode is 'Regulator', bandwidth is 500MB/s and saturation is 1024.
- The bandwidth must be calculated based on actual operating frequency.
- Refer to chapter 7.4 for detail register. All generators have the same register except the valid bits of 'Bandwidth' filed may be different.

### 1.3.2 Memory Scheduler

Memory scheduler is a special NIU of the interconnect, it mainly deal with the transaction inside the interconnect and convert it to the transaction which the ddr protocol controller can recognize.

Following table shows the software configurable setting for the memory scheduler when the system connected to different size of ddr device.

The DEVICE CONF is a configurable register inside interconnect .

R: indicates Row bits

B: indicates Bank bits

C: indicates Column bits

G: indicates Bank Group bits for DDR4

Table 1-2 'ddrconf' item

|    |                                   |
|----|-----------------------------------|
| 0  | RRRRRRRRRRRRRRRRRRBBCCCC--<br>--- |
| 1  | RRRRRRRRRRRRRRRRRRBBCCCC--<br>--- |
| 2  | RRRRRRRRRRRRRRRRBBCCCC--<br>---   |
| 3  | RRRRRRRRRRRRRRRRBBCCCC--<br>---   |
| 4  | RRRRRRRRRRRRRRBBCCCC--<br>---     |
| 5  | RRRRRRRRRRRRRRBBCCCC--<br>---     |
| 6  | RRCRRRRRRRRRRRRBBCCCC--<br>---    |
| 7  | RRRRRRRRRRRRRRBBGCCCCCG--<br>---  |
| 8  | RRRRRRRRRRRRRRBBGCCCCCG--<br>---  |
| 9  | RRRRRRRRRRRRRRBBGCCCCCGC--<br>--- |
| 10 | RRRRRRRRRRRRRRBBCCCCCGC--<br>---  |
| 11 | RRRRRRRRRRRRRRBBCCCCCG--<br>---   |
| 12 | RRRRRRRRRRRRRRBBCCCCCCC--<br>---  |

In order to get best performance, some DDR controller and DRAM related timing parameters must be programmed properly in memory schedule registers.

### 1.3.3 Probe

The interconnect provides a service called probe to trace packet and compute traffic statics, There are totally 4 probes to monitor the memory schedule traffic statics and each can be programmed by their register. They are listed below.

Table 1-3 Probe

| Probe Name | Monitor Path                         | Register Base Address |
|------------|--------------------------------------|-----------------------|
| cpu_probe  | cpu to memory schedule               | 0xff532000            |
| gpu_probe  | gpu to memory schedule               | 0xff532400            |
| mmip_probe | multimedia master to memory schedule | 0xff532800            |
| peri_probe | peripheral master to memory schedule | 0xff532c00            |

Refer to chapter 7.4 for detail register.

### 1.3.4 Bank Interleave

There is a particular module in the interconnect named DDR\_BANK\_HASH to do bank interleaving for performance improvement. When it is enabled (GRF\_DDR\_BANKHASH\_CTRL[0]=1'b1), the bank bits in the raw physical address will be set to a new one. The bank interleave formula, assuming 3 bank bits, is as follows:

$$\text{bank}[2:0] = \text{msb\_swizzle}[2:0]^{\wedge} \text{manicure\_swizzle}[2:0]^{\wedge} \text{bank\_base}[2:0];$$

The terms in the equation are:

- 1 **bank\_base:** This is the raw bank number from the physical address
- 2 **manicure\_swizzle:** This swizzles the bank bits within the manicure region to give an ideal interleave of banks within the region
- 3 **msb\_swizzle:** This is a hash of address MSBs that is constant for each manicure region but random from one manicure region to the next, with special care taken to prevent horizontal abutment conflicts

```

bank_offset[2:0] = GRF_DDR_BANKHASH_CTRL[6:4]
addr_shift = {addr>>(10+ bank_offset)}
bank_base[2:0] = addr_shift[2:0]
manicure_mask[2:0] = GRF_DDR_BANKHASH_CTRL[3:1]
manicure_swizzle[2:0] = {addr_shift[5]^addr_shift[3],addr_shif[4],addr_shift[3]} &
manicure_mask[2:0]
bank0_mask = GRF_DDR_BANK_MASK0[31:0]
bank1_mask = GRF_DDR_BANK_MASK1[31:0]
bank2_mask = GRF_DDR_BANK_MASK2[31:0]
msb_swizzle[0] = raw_addr[31:0] & bank0_mask
msb_swizzle[1] = raw_addr[31:0] & bank1_mask
msb_swizzle[2] = raw_addr[31:0] & bank2_mask

```

For CPU, the address above 0xff000000 will not be hashed.

### 1.3.5 DDR Hold

The DDR\_HOLD module can hold AXI traffics to DDR controller for a specific memory scheduler clock cycles to gather traffics as more as possible for power efficiency. This module can only chose when DDR\_BUFFURE module is not chose (DDR\_GRF\_DDR\_CON0.grf\_ddrbuf\_en=1'b0, the default value is 1'b1).

After enabled (DDR\_GRF.MSC\_CTRL.global\_en=1 and

DDR\_GRF\_DDR\_CON0.grf\_ddrbuf\_en=1'b0), the traffics will be held in memory scheduler for DDR\_GRF.READY\_LOW\_CYCLES and then transferred to DDR controller for DDR\_GRF.READY\_HIGH\_CYCLES.

To reduce CPU traffics' latency, set DDR\_GRF.MSC\_CTRL.cpu\_bypass\_en to 1'b1. In this case, only if there is not any CPU traffics during DDR\_GRF.CPU\_IDLE\_TH clock cycles that this module will hold all the traffics.

To reduce high priority traffics' latency, set DDR\_GRF.MSC\_CTRL.priority\_bypass\_en to 1'b1. In this case, only when there is not any traffics whose priority is higher than DDR\_GRF.PRIORITY\_LEVEL\_TH during DDR\_GRF.PRIORITY\_IDLE\_TH clock cycles that this module will hold all the traffics.

To reduce read latency for all traffics, set DDR\_GRF.MSC\_CTRL.read\_bypass\_en to 1'b1. In this case, all read traffics will not be held and issued to DDR controller directly.

## 1.4 Register Description

### 1.4.1 QoS Registers Summary

| Name                     | Offset | Size | Reset Value | Description          |
|--------------------------|--------|------|-------------|----------------------|
| <u>QOS_Id_CoreId</u>     | 0x0000 | W    | 0x0d867004  | Core id              |
| <u>QOS_Id_RevisionId</u> | 0x0004 | W    | 0x0001aa00  | Revision id          |
| <u>QOS_Priority</u>      | 0x0008 | W    | 0x80000101  | QoS priority         |
| <u>QOS_Mode</u>          | 0x000c | W    | 0x00000000  | Qos mode selection   |
| <u>QOS_Bandwidth</u>     | 0x0010 | W    | 0x0000018a  | QoS bandwidth        |
| <u>QOS_Saturation</u>    | 0x0014 | W    | 0x00000040  | QoS saturation       |
| <u>QOS_ExtControl</u>    | 0x0018 | W    | 0x00000000  | Qos external control |

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

### 1.4.2 QoS Detail Register Description

#### QOS\_Id\_CoreId

Address: Operational Base + offset (0x0000)

| Bit  | Attr | Reset Value | Description                                                             |
|------|------|-------------|-------------------------------------------------------------------------|
| 31:8 | RO   | 0x0d8670    | CoreChecksum<br>Field containing a checksum of the parameters of the IP |
| 7:0  | RO   | 0x04        | CoreTypeId<br>Field identifying the type of IP                          |

#### QOS\_Id\_RevisionId

Address: Operational Base + offset (0x0004)

| Bit  | Attr | Reset Value | Description            |
|------|------|-------------|------------------------|
| 31:0 | RO   | 0x0001aa00  | RevisionId<br>Constant |

#### QOS\_Priority

Address: Operational Base + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RO          | 0x1                | Mark<br>Backward compatibility marker when 0                                                                                                                                                                                                                             |
| 30:10      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                 |
| 9:8        | RW          | 0x1                | P1<br>In Programmable or Bandwidth Limiter mode, the priority level for read transactions. In Bandwidth regulator mode, the priority level when the used throughput is below the threshold. In Bandwidth Regulator mode, P1 should have a value equal or greater than P0 |
| 7:2        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                 |
| 1:0        | RW          | 0x1                | P0<br>In Programmable or Bandwidth Limiter mode, the priority level for write transactions. In Bandwidth Regulator mode, the priority level when the used throughput is above the threshold. In Bandwidth Regulator mode, P0 should have a value equal or lower than P1  |

**QOS Mode**

Address: Operational Base + offset (0x000c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                |
| 1:0        | RW          | 0x0                | Mode<br>0 = Programmable mode: a programmed priority is assigned to each read or write,<br>1 = Bandwidth Limiter Mode: a hard limit restricts throughput,<br>2 = Bypass mode: (<See SoC-specific QoS generator documentation>),<br>3 = Bandwidth Regulator mode: priority decreases when throughput exceeds a threshold |

**QOS Bandwidth**

Address: Operational Base + offset (0x0010)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:12      | RO          | 0x0                | reserved                                                                                                                                                                                                                                          |
| 11:0       | RW          | 0x18a              | Bandwidth<br>In Bandwidth Limiter or Bandwidth Regulator mode, the bandwidth threshold in units of 1/256th bytes per cycle. For example, 80 MBps on a 250 MHz interface is value 0x0052. The valid bits may be different for different master NIU |

**QOS Saturation**

Address: Operational Base + offset (0x0014)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                   |
| 9:0        | RW          | 0x040              | Saturation<br>In Bandwidth Limiter or Bandwidth Regulator mode, the maximum data count value, in units of 16 bytes. This determines the window of time over which bandwidth is measured. For example, to measure bandwidth within a 1000 cycle window on a 64-bit interface is value 0x1F4 |

**QOS ExtControl**

Address: Operational Base + offset (0x0018)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                       |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                 |
| 0          | RW          | 0x0                | SocketQosEn<br>Register field SocketQosEn determines how priority levels are driven when QoS generators and socket interfaces alternatively drive the levels for Urgency, Pressure, and Hurry signals: When set to 0, the QoS generator drives the levels. When set to 1, internal signals Pressure and Hurry are driven by the greater of the two levels from the socket interface or the QoS generator |

### **1.4.3 Memory Schedule Registers Summary**

| <b>Name</b>               | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                     |
|---------------------------|---------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <u>MSCH_Id_CoreId</u>     | 0x0000        | W           | 0x00dc1b18         | Core id                                                                                                                                                                                                                |
| <u>MSCH_Id_RevisionId</u> | 0x0004        | W           | 0x0001aa00         | Revision id                                                                                                                                                                                                            |
| <u>MSCH_DeviceConf</u>    | 0x0008        | W           | 0x00000000         | Register DeviceConf stores selectors to the predefined list of DDR configuration to be programmed at initialization phase. The register has two fields, Rank0 and Rank1                                                |
| <u>MSCH_DeviceSize</u>    | 0x000c        | W           | 0x00000000         | Register DeviceSize is used to set the size of DDR ranks                                                                                                                                                               |
| <u>MSCH_DdrTimingA0</u>   | 0x0010        | W           | 0x28140916         | Register DdrTimingA(n) of timing register bank n stores timing settings used by memory schedulers to compute bank and page states                                                                                      |
| <u>MSCH_DdrTimingB0</u>   | 0x0014        | W           | 0x12040702         | Register DdrTimingB(n) of timing register bank n stores timing settings used by memory schedulers to compute penalties pertaining to bank and page states                                                              |
| <u>MSCH_DdrTimingC0</u>   | 0x0018        | W           | 0x00000602         | Register DdrTimingC(n) of timing register bank n: Stores timing settings used by memory schedulers to compute penalties pertaining to DRAM commands. Is used to configure the clock of the register bank               |
| <u>MSCH_DevToDev0</u>     | 0x001c        | W           | 0x00002222         | Register DevToDev(n) of timing register bank n contains supplementary timing penalties that are incurred when changing data-bus ownership of up to four devices. The penalties are expressed in scheduler clock cycles |
| <u>MSCH_DdrMode</u>       | 0x0110        | W           | 0x0000004c         | Register DdrMode stores the controller behavior description                                                                                                                                                            |
| <u>MSCH_Ddr4Timing</u>    | 0x0114        | W           | 0x00000000         | Long timing for DDR4 Bank Group support                                                                                                                                                                                |
| <u>MSCH_AgingX0</u>       | 0x1000        | W           | 0x00000004         | Aging threshold multiplicator                                                                                                                                                                                          |
| <u>MSCH_Aging0</u>        | 0x1040        | W           | 0x00000000         | AGING slice threshold for port 0                                                                                                                                                                                       |
| <u>MSCH_Aging1</u>        | 0x1044        | W           | 0x00000000         | AGING slice threshold for port 1                                                                                                                                                                                       |
| <u>MSCH_Aging2</u>        | 0x1048        | W           | 0x00000000         | AGING slice threshold for port 2                                                                                                                                                                                       |

|             |        |   |            |                                  |
|-------------|--------|---|------------|----------------------------------|
| MSCH_Aging3 | 0x104c | W | 0x00000000 | AGING slice threshold for port 3 |
|-------------|--------|---|------------|----------------------------------|

Notes:**B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access  
Base address for memory schedule 0 is 0ffa84000 and for memory schedule 1 is 0ffa8c0000.

#### 1.4.4 Memory schedule Detail Register Description

##### **MSCH\_Id\_CoreId**

Address: Operational Base + offset (0x0000)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                  |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | RO   | 0x00dc1b    | CoreChecksum<br>Field containing a checksum of the parameters of the IP.<br>For memory schedule 0 , this value is 0x00dc1b<br>For memory schedule 1 , this value is 0xc2f11d |
| 7:0  | RO   | 0x18        | CoreTypeId<br>Field identifying the type of IP                                                                                                                               |

##### **MSCH\_Id\_RevisionId**

Address: Operational Base + offset (0x0004)

| Bit  | Attr | Reset Value | Description            |
|------|------|-------------|------------------------|
| 31:0 | RO   | 0x0001aa00  | RevisionId<br>Constant |

##### **MSCH\_DeviceConf**

Address: Operational Base + offset (0x0008)

| Bit   | Attr | Reset Value | Description                                                 |
|-------|------|-------------|-------------------------------------------------------------|
| 31:14 | RO   | 0x0         | reserved                                                    |
| 13:8  | RW   | 0x00        | Rank1<br>Rank1 selector of predefined ddrConf configuration |
| 7:0   | RW   | 0x00        | Rank0<br>Rank0 selector of predefined ddrConf configuration |

##### **MSCH\_DeviceSize**

Address: Operational Base + offset (0x000c)

| Bit   | Attr | Reset Value | Description                                   |
|-------|------|-------------|-----------------------------------------------|
| 31:16 | RO   | 0x0         | reserved                                      |
| 15:8  | RW   | 0x00        | Rank1<br>Rank0 size.The granule size is 64MB  |
| 7:0   | RW   | 0x00        | Rank0<br>Rank0 size. The granule size is 64MB |

##### **MSCH\_DdrTimingA0**

Address: Operational Base + offset (0x0010)

| Bit   | Attr | Reset Value | Description                                                                     |
|-------|------|-------------|---------------------------------------------------------------------------------|
| 31:24 | RW   | 0x28        | ReadLatency<br>Maximun delay between a read request and the first data response |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23:22      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                     |
| 21:16      | RW          | 0x14               | <p>WrToMiss<br/>Minimum number of scheduler clock cycles between the last DRAM Write command and a new Read or Write command in another page of the same bank.<br/>The field must be set to the following value, rounded to an integer number of scheduler clock cycles:<br/><math>(WL \times tCkD + tWR + tRP + tRCD) / tCkG</math></p>     |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                     |
| 13:8       | RW          | 0x09               | <p>RdToMiss<br/>Minimum number of scheduler clock cycles between the last DRAM Read command and a new Read or Write command in another page of the same bank.<br/>The field must be set to the following value, rounded to an integer number of scheduler clock cycles:<br/><math>(tRTP + tRP + tRCD - BL \times tCkD / 2) / tCkG</math></p> |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                     |
| 5:0        | RW          | 0x16               | <p>ActToAct<br/>Minimum number of scheduler clock cycles between two consecutive DRAM Activate commands on the same bank.<br/>The field must be set to the following value, rounded to an integer number of scheduler clock cycles:<br/><math>tRC / tCkG</math></p>                                                                          |

**MSCH\_DdrTimingB0**

Address: Operational Base + offset (0x0014)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                                                                                                                                                                                                                               |
| 29:24      | RW          | 0x12               | <p>Faw<br/>Number of cycle of the FAW period.<br/>The field must be set to the following value, rounded to an integer number of scheduler clock cycles:<br/><math>tFAW / tCkG</math></p>                                                               |
| 23:20      | RO          | 0x0                | reserved                                                                                                                                                                                                                                               |
| 19:16      | RW          | 0x4                | <p>Rrd<br/>Number of cycle between two consecutive Activate commands on different Banks of the same device.<br/>The field must be set to the following value, rounded to an integer number of scheduler clock cycles:<br/><math>tRRD / tCkG</math></p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:13      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                    |
| 12:8       | RW          | 0x07               | <p>WrToRd<br/>Minimum number of scheduler clock cycles between the last DRAM Write command and a Read command.<br/>The field must be set to the following value, rounded to an integer of scheduler clock cycles:<br/> <math>(WL \times tCkD + tWTR) / tCkG</math>, for DDR2 and DDR3 memories.<br/> <math>(WL \times tCkD + tWTR\_S) / tCkG</math>, for DDR4 memories.</p> |
| 7:5        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                    |
| 4:0        | RW          | 0x02               | <p>RdToWr<br/>Minimum number of scheduler clock cycles between the last DRAM Read command and a Write command.<br/>The field must be set to the following value, rounded to an integer number of scheduler clock cycles:<br/> <math>2 \times tCkD / tCkG</math>, for DDR2 memories.<br/> <math>(RL - WL + 2) \times tCkD / tCkG</math>, for DDR3 and DDR4 memories.</p>     |

**MSCH\_DdrTimingC0**

Address: Operational Base + offset (0x0018)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                     |
| 13:8       | RW          | 0x06               | <p>WrToMwr<br/>Number of scheduler clock cycles between the last write data to the first data of a masked write command on the same bank.<br/>This field must be set to 3xBurstPenalty, and must be set to zero for the other DRAM</p>                                                                                                       |
| 7:4        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                     |
| 3:0        | RW          | 0x2                | <p>BurstPenalty<br/>DRAM burst duration on the DRAM data bus in scheduler clock cycles.<br/>The field must be set to Nd /Ns, where:<br/>Nd is the number of DRAM cycles needed to process a DRAM burst of determined size, expressed in bytes.<br/>Ns is the minimum number of scheduler cycles to process a DRAM burst of the same size</p> |

**MSCH\_DevToDev0**

Address: Operational Base + offset (0x001c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:15      | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 14:12      | RW          | 0x2                | BusWrToWr<br>number of cycle between the last write data to a device and the first write data of another device.<br>The field must be set according to the third-party DDR controller specification |
| 11         | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 10:8       | RW          | 0x2                | BusWrToRd<br>number of cycle between the last write data to a device and the first read data of another device.<br>The field must be set according to the third-party DDR controller specification  |
| 7          | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 6:4        | RW          | 0x2                | BusRdToWr<br>number of cycle between the last read data of a device and the first write data to another device.<br>The field must be set according to the third-party DDR controller specification  |
| 3          | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 2:0        | RW          | 0x2                | BusRdToRd<br>number of cycle between the last read data of a device and the first read data of another device.<br>The field must be set according to the third-party DDR controller specification   |

**MSCH\_DdrMode**

Address: Operational Base + offset (0x0110)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                      |
| 23:16      | RO          | 0x00               | ForceOrderState<br>ForceOrderState                                                                                                                                                                                                                                                            |
| 15:8       | RW          | 0x00               | ForceOrder<br>When bit n of register field ForceOrder is set to 1, DRAM commands are executed in the order they arrive at scheduler port n.<br>When field bits are set to 1, and BypassFiltering is also set to 1, command execution order is guaranteed for the corresponding scheduler port |
| 7          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                      |
| 6:5        | RW          | 0x2                | reserved                                                                                                                                                                                                                                                                                      |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |          |          |          |           |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|----------|----------|-----------|
| 4:3        | RW          | 0x1                | <p>BurstSize</p> <p>Register field BurstSize sets the DDR burst size, in bytes, as shown by the following table.</p> <table> <tr><td>2'b00:16</td></tr> <tr><td>2'b01:32</td></tr> <tr><td>2'b10:64</td></tr> <tr><td>2'b11:128</td></tr> </table>                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 2'b00:16 | 2'b01:32 | 2'b10:64 | 2'b11:128 |
| 2'b00:16   |             |                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |          |          |          |           |
| 2'b01:32   |             |                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |          |          |          |           |
| 2'b10:64   |             |                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |          |          |          |           |
| 2'b11:128  |             |                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |          |          |          |           |
| 2          | RW          | 0x1                | <p>FawBank</p> <p>Register field FawBank indicates the number of banks of a given device involved in the FAW period during which four banks can be active. It must be set to 0 for 2-bank memories, and 1 for memories with four banks or more</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                          |          |          |          |           |
| 1          | RW          | 0x0                | <p>BypassFiltering</p> <p>When register field BypassFiltering is set to 1, arbiter filters are bypassed and timing register outputs are internally set to an idle value. The field can be useful during DRAM initialization, when training or calibration sequences are performed, and scheduler arbitration is not needed.</p> <p>When the field is set to 0, scheduler arbitration is fully functional, this is the functional usage mode.</p> <p>NOTE: When the field is set to 1, the final arbitration level continues to elect transactions among those presented to the arbiter. Set field ForceOrder to ensure that transactions are executed in order, for instance during DRAM initialization</p> |          |          |          |           |
| 0          | RW          | 0x0                | <p>AutoPrecharge</p> <p>When set to one, pages are automatically closed after each access, when set to zero, pages are left opened until an access in a different page occurs</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |          |          |          |           |

**MSCH\_Ddr4Timing**

Address: Operational Base + offset (0x0114)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11:8       | RW          | 0x0                | RrdL<br>Register field RrdL stores the minimum number of scheduler clock cycles on the DRAM command bus, between two Activate commands to different banks of the same bank group in the same device.<br>The filed must be set to tRRD_L/tCkG                                                                                 |
| 7:3        | RW          | 0x00               | WrToRdL<br>Register field WrToRdL stores the result of nMin -tData, where nMin is the minimum number of scheduler clock cycles on the DRAM command bus in the interval between a Write command and the next Read command to an already opened page in the same bank group.<br>The filed must be set to (WLxtCkD+tWTR_L)/tCkG |
| 2:0        | RW          | 0x0                | CcdL<br>Register field CcdL sets the minimum number of scheduler clock cycles between column access commands to an already opened page in the same bank group.<br>The file must be set to: tCCD_L/tCkG                                                                                                                       |

**MSCH AgingX0**

Address: Operational Base + offset (0x1000)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                       |
|------------|-------------|--------------------|------------------------------------------|
| 31:3       | RO          | 0x0                | reserved                                 |
| 2:0        | RW          | 0x4                | AgingX0<br>Aging threshold multiplicator |

**MSCH Aging0**

Address: Operational Base + offset (0x1040)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                         |
|------------|-------------|--------------------|--------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                   |
| 7:0        | RW          | 0x00               | Aging0<br>AGING slice threshold for port 0 |

**MSCH Aging1**

Address: Operational Base + offset (0x1044)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                         |
|------------|-------------|--------------------|--------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                   |
| 7:0        | RW          | 0x00               | Aging1<br>AGING slice threshold for port 1 |

**MSCH Aging2**

Address: Operational Base + offset (0x1048)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                         |
|------------|-------------|--------------------|--------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                   |
| 7:0        | RW          | 0x00               | Aging2<br>AGING slice threshold for port 2 |

**MSCH Aging3**

Address: Operational Base + offset (0x104c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                         |
|------------|-------------|--------------------|--------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                   |
| 7:0        | RW          | 0x00               | Aging3<br>AGING slice threshold for port 3 |

**1.4.5 Probe Registers Summary**

| <b>Name</b>                 | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                      |
|-----------------------------|---------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <u>PROBE_Id_CoreId</u>      | 0x0000        | W           | 0x0d867006         | Core id                                                                                                                                                                                 |
| <u>PROBE_Id_RevisionId</u>  | 0x0004        | W           | 0x0001aa00         | Revision id                                                                                                                                                                             |
| <u>PROBE_MainCtl</u>        | 0x0008        | W           | 0x00000000         | Register MainCtl contains probe global control bits                                                                                                                                     |
| <u>PROBE_CfgCtl</u>         | 0x000c        | W           | 0x00000000         | Register CfgCtl contains global enable and active bits. The register, which must be used by software before changing certain packet probe global registers                              |
| <u>PROBE_StatPeriod</u>     | 0x0024        | W           | 0x00000000         | Statistics Period                                                                                                                                                                       |
| <u>PROBE_StatGo</u>         | 0x0028        | W           | 0x00000000         | Statistics begin control                                                                                                                                                                |
| <u>PROBE_Counters_0_Src</u> | 0x0138        | W           | 0x00000000         | Register CntSrc indicates the event source used to increment the counter. Unassigned values (non-existing Press level or ExtEvent index, or unimplemented Filter) are equivalent to OFF |
| <u>PROBE_Counters_0_Val</u> | 0x0140        | W           | 0x00000000         | Registers Counters_M_Val contain the statistics counter values                                                                                                                          |

| Name                 | Offset | Size | Reset Value | Description                                                                                                                                                                             |
|----------------------|--------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PROBE_Counters_1_Src | 0x014c | W    | 0x00000000  | Register CntSrc indicates the event source used to increment the counter. Unassigned values (non-existing Press level or ExtEvent index, or unimplemented Filter) are equivalent to OFF |
| PROBE_Counters_1_Val | 0x0154 | W    | 0x00000000  | Registers Counters_M_Val contain the statistics counter values                                                                                                                          |
| PROBE_Counters_2_Src | 0x0160 | W    | 0x00000000  | Register CntSrc indicates the event source used to increment the counter. Unassigned values (non-existing Press level or ExtEvent index, or unimplemented Filter) are equivalent to OFF |
| PROBE_Counters_2_Val | 0x0168 | W    | 0x00000000  | Registers Counters_M_Val contain the statistics counter values                                                                                                                          |
| PROBE_Counters_3_Src | 0x0174 | W    | 0x00000000  | Register CntSrc indicates the event source used to increment the counter. Unassigned values (non-existing Press level or ExtEvent index, or unimplemented Filter) are equivalent to OFF |
| PROBE_Counters_3_Val | 0x017c | W    | 0x00000000  | Registers Counters_M_Val contain the statistics counter values                                                                                                                          |

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

#### 1.4.6 Probe Detail Register Description

##### PROBE\_Id\_CoreId

Address: Operational Base + offset (0x0000)

| Bit  | Attr | Reset Value | Description                                                             |
|------|------|-------------|-------------------------------------------------------------------------|
| 31:8 | RO   | 0x0d8670    | CoreChecksum<br>Field containing a checksum of the parameters of the IP |
| 7:0  | RO   | 0x06        | CoreTypeId<br>Field identifying the type of IP                          |

##### PROBE\_Id\_RevisionId

Address: Operational Base + offset (0x0004)

| Bit  | Attr | Reset Value | Description         |
|------|------|-------------|---------------------|
| 31:0 | RO   | 0x0001aa00  | RevisionId Constant |

**PROBE MainCtl**

Address: Operational Base + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 7          | RW          | 0x0                | FiltByteAlwaysChainableEn<br>When set to 0, filters are mapped to all statistic counters when counting bytes or enabled bytes. Therefore, only filter events mapped to even counters can be counted using a pair of chained counters. When set to 1, filters are mapped only to even statistic counters when counting bytes or enabled bytes. Thus events from any filter can be counted using a pair of chained counters |
| 6          | RO          | 0x0                | IntrusiveMode<br>When set to 1, register field IntrusiveMode enables trace operation in Intrusive flow-control mode. When set to 0, the register enables trace operation in Overflow flow-control mode                                                                                                                                                                                                                    |
| 5          | RW          | 0x0                | StatCondDump<br>When set, register field StatCondDump enables the dump of a statistics frame to the range of counter values set for registers StatAlarmMin, StatAlarmMax, and AlarmMode. This field also renders register StatAlarmStatus inoperative. When parameter statisticsCounterAlarm is set to False, the StatCondDump register bit is reserved                                                                   |
| 4          | RW          | 0x0                | AlarmEn<br>When set, register field AlarmEn enables the probe to collect alarm-related information. When the register field bit is null, both TraceAlarm and StatAlarm outputs are driven to 0                                                                                                                                                                                                                            |
| 3          | RW          | 0x0                | StatEn<br>When set to 1, register field StatEn enables statistics profiling. The probe sends statistics results to the output for signal ObsTx. All statistics counters are cleared when the StatEn bit goes from 0 to 1. When set to 0, counters are disabled                                                                                                                                                            |
| 2          | RW          | 0x0                | PayloadEn<br>Register field PayloadEn, when set to 1, enables traces to contain headers and payload. When set to 0, only headers are reported                                                                                                                                                                                                                                                                             |
| 1          | RO          | 0x0                | TraceEn<br>Register field TraceEn enables the probe to send filtered packets (Trace) on the ObsTx observation output                                                                                                                                                                                                                                                                                                      |
| 0          | RW          | 0x0                | ErrEn<br>Register field ErrEn enables the probe to send on the ObsTx output any packet with Error status, independently of filtering mechanisms, thus constituting a simple supplementary global filter                                                                                                                                                                                                                   |

**PROBE CfgCtl**

Address: Operational Base + offset (0x000c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                 |
| 1          | RO          | 0x0                | Active<br>Register field Active is used to inform software that the probe is active. Probe configuration is not allowed during the active state. This bit is raised when bit GlobalEn is set, and is cleared a few cycles after setting GlobalEn to zero (probe is Idle) |
| 0          | RW          | 0x0                | GlobalEn<br>Set register field GlobalEn to 1 enable the tracing and statistics collection sub-systems of the packet probe                                                                                                                                                |

**PROBE StatPeriod**

Address: Operational Base + offset (0x0024)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 4:0        | RW          | 0x00               | StatPeriod<br>Register StatPeriod is a 5-bit register that sets a period, within a range of 2 cycles to 2 gigacycles, during which statistics are collected before being dumped automatically. Setting the register implicitly enables automatic mode operation for statistics collection. The period is calculated with the formula: N_Cycle = 2**StatPeriodWhen register StatPeriod is set to its default value 0, automatic dump mode is disabled, and register StatGo is activated for manual mode operation. Note: When parameter statisticsCollection is set to False, StatPeriod is reserved |

**PROBE StatGo**

Address: Operational Base + offset (0x0028)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                |
| 0          | RW          | 0x0                | StatGo<br>Writing a 1 to the 1-bit pulse register StatGo generates a statistics dump. The register is active when statistics collection operates in manual mode, that is, when register StatPeriod is set to 0. NOTE The written value is not stored in StatGo. A read always returns 0 |

**PROBE Counters 0 Src**

Address: Operational Base + offset (0x0138)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4:0        | RW          | 0x00               | <p>IntEvent<br/>Internal packet event</p> <p>5'h00 OFF Counter disabled.</p> <p>5'h01 CYCLE8 Probe clock cycles.</p> <p>5'h02 IDLE Idle cycles during which no packet data is observed.</p> <p>5'h03 XFER Transfer cycles during which packet data is transferred.</p> <p>5'h04 BUSY Busy cycles during which the packet data is made available by the transmitting agent but the receiving agent is not ready to receive it.</p> <p>5'h05 WAIT Wait cycles during a packet in which the transmitting agent suspends the transfer of packet data.</p> <p>5'h06 PKT Packets.</p> <p>5'h08 BYTE Total number of payload bytes.</p> <p>5'h09 PRESS Clock cycles with pressure level &gt; 0.</p> <p>5'h0A PRESS Clock cycles with pressure level &gt; 1.</p> <p>5'h0B PRESS Clock cycles with pressure level &gt; 2.</p> <p>5'h10 CHAIN Carry from counter 2m to counter 2m + 1</p> |

**PROBE Counters 0 Val**

Address: Operational Base + offset (0x0140)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                   |
| 15:0       | RO          | 0x0000             | Counters_0_Val<br>Register Val is a read-only register that is always present. The register contains the statistics counter value either pending StatAlarm output, or when statistics collection is suspended subsequent to triggers or signal statSuspend |

**PROBE Counters 1 Src**

Address: Operational Base + offset (0x014c)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4:0        | RW          | 0x00               | <p>IntEvent<br/>Internal packet event<br/>Event   source type   Event description</p> <p>5'h00 OFF Counter disabled.<br/>5'h01 CYCLE8 Probe clock cycles.<br/>5'h02 IDLE Idle cycles during which no packet data is observed.<br/>5'h03 XFER Transfer cycles during which packet data is transferred.<br/>5'h04 BUSY Busy cycles during which the packet data is made available by the transmitting agent but the receiving agent is not ready to receive it.<br/>5'h05 WAIT Wait cycles during a packet in which the transmitting agent suspends the transfer of packet data.<br/>5'h06 PKT Packets.<br/>5'h08 BYTE Total number of payload bytes.<br/>5'h09 PRESS Clock cycles with pressure level &gt; 0.<br/>5'h0A PRESS Clock cycles with pressure level &gt; 1.<br/>5'h0B PRESS Clock cycles with pressure level &gt; 2.<br/>5'h10 CHAIN Carry from counter 2m to counter 2m + 1</p> |

**PROBE Counters 1 Val**

Address: Operational Base + offset (0x0154)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                   |
| 15:0       | RO          | 0x0000             | Counters_0_Val<br>Register Val is a read-only register that is always present. The register contains the statistics counter value either pending StatAlarm output, or when statistics collection is suspended subsequent to triggers or signal statSuspend |

**PROBE Counters 2 Src**

Address: Operational Base + offset (0x0160)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4:0        | RW          | 0x00               | <p>IntEvent<br/>Internal packet event<br/>Event   source type   Event description</p> <p>5'h00 OFF Counter disabled.<br/>5'h01 CYCLE8 Probe clock cycles.<br/>5'h02 IDLE Idle cycles during which no packet data is observed.<br/>5'h03 XFER Transfer cycles during which packet data is transferred.<br/>5'h04 BUSY Busy cycles during which the packet data is made available by the transmitting agent but the receiving agent is not ready to receive it.<br/>5'h05 WAIT Wait cycles during a packet in which the transmitting agent suspends the transfer of packet data.<br/>5'h06 PKT Packets.<br/>5'h08 BYTE Total number of payload bytes.<br/>5'h09 PRESS Clock cycles with pressure level &gt; 0.<br/>5'h0A PRESS Clock cycles with pressure level &gt; 1.<br/>5'h0B PRESS Clock cycles with pressure level &gt; 2.<br/>5'h10 CHAIN Carry from counter 2m to counter 2m + 1</p> |

**PROBE Counters 2 Val**

Address: Operational Base + offset (0x0168)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                   |
| 15:0       | RO          | 0x0000             | Counters_0_Val<br>Register Val is a read-only register that is always present. The register contains the statistics counter value either pending StatAlarm output, or when statistics collection is suspended subsequent to triggers or signal statSuspend |

**PROBE Counters 3 Src**

Address: Operational Base + offset (0x0174)

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

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4:0 | RW   | 0x00        | <p>IntEvent<br/>Internal packet event<br/>Event   source type   Event description</p> <p>5'h00 OFF Counter disabled.<br/>5'h01 CYCLE8 Probe clock cycles.<br/>5'h02 IDLE Idle cycles during which no packet data is observed.<br/>5'h03 XFER Transfer cycles during which packet data is transferred.<br/>5'h04 BUSY Busy cycles during which the packet data is made available by the transmitting agent but the receiving agent is not ready to receive it.<br/>5'h05 WAIT Wait cycles during a packet in which the transmitting agent suspends the transfer of packet data.<br/>5'h06 PKT Packets.<br/>5'h08 BYTE Total number of payload bytes.<br/>5'h09 PRESS Clock cycles with pressure level &gt; 0.<br/>5'h0A PRESS Clock cycles with pressure level &gt; 1.<br/>5'h0B PRESS Clock cycles with pressure level &gt; 2.<br/>5'h10 CHAIN Carry from counter 2m to counter 2m + 1</p> |

### PROBE Counters 3 Val

Address: Operational Base + offset (0x017c)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                   |
| 15:0  | RO   | 0x0000      | Counters_0_Val<br>Register Val is a read-only register that is always present. The register contains the statistics counter value either pending StatAlarm output, or when statistics collection is suspended subsequent to triggers or signal statSuspend |

## 1.5 Application Notes

### 1.5.1 QoS setting

The VOP and isp have the external QoS control.

It's recommended that field 0 of QoS\_ExtControl set to 1 to enable the external qos control. And priority setting of each master kept at 1.

### 1.5.2 Idle request

The main interconnect supports flushing the ongoing transaction when the software needed to do so.

If the GPU power domain need to disconnect from the main interconnect, Idle request has to be sent to GPU NIU, the NIU will respond a ack, and when it's ready to be disconnect, one Idle signal will be send out . Then, if GPU still have transaction to be sent to the memory scheduler, it will be stalled by the NIU.

If the GPU system power domain is disconnected as the above flow, then CPU want to access

to the GPU system, it will response error or held to CPU according to the corresponding grf register setting.

The sequence is like following figure shows:



Fig. 1-2 Idle request

The idle request is set by GRF register.

### 1.5.3 Basic Packet Tracing

To trace packets, the packet probe must be programmed as follows:

- Select the interesting probe listed in section 7.3.4.
- Set field *TraceEn* of register *MainCtl* to 1 to enable forwarding of traced packets to the connected observer. Optionally set field *PayloadEn* of register *MainCtl* to 1 if the packet payload should be included in the trace.
- Set field *GlobalEn* of register *CfgCtl* to 1.

### 1.5.4 Counting packets over a fixed period

The following programming sequence counts packets at a given probe point using statistic counter 0.

- Select the interesting probe listed in section 7.3.4
- Set field *StatEn* to 1 in register *MainCtl*.
- Set register *Counters\_0\_Src* to 0x6 (PKT) to count packets.
- Specify the period during which the packets should be counted by setting register *StatPeriod* to:  $\log_2(\text{interval expressed in number of probe clock cycles})$
- Set field *GlobalEn* of register *CfgCtl* to 1 to enable packet counting.

Once time  $2^{\text{StatPeriod}}$  has elapsed, the number of packets counted is dumped to the observer and can be read from *Counters\_0\_Val*.

### 1.5.5 Measuring bandwidth

The following programming sequence example shows how a packet probe can be used to measure bandwidth at a probe point.

Some important points to note about this example are:

- Statistics counters are chained together to support the maximum theoretical bandwidth. Counter 0 is configured to count bytes; counter 1 increments when counter 0 rolls over.
- The counter values are dumped to an observer after time  $2^{\text{StatPeriod}}$ .

The programming sequence is as follows:

- Select the interesting probe listed in section 7.3.4
- Set register *Counters\_0\_Src* to 0x8 (BYTES) to count bytes.
- Set register *Counters\_1\_Src* to 0x10 (CHAIN) to increment when counter 0 wraps.
- Specify the period during which the bytes should be counted by setting register *StatPeriod* to:  $\log_2(\text{interval expressed in number of probe clock cycles})$ .
- Set field *GlobalEn* of register *CfgCtl* to 1 to enable the counting of bytes.

Once time  $2^{\text{StatPeriod}}$  has elapsed, the number of packets counted is dumped to the observer and can be read from *Counters\_0\_Val* and *Counters\_1\_Val*.

## Chapter 2 Dynamic Memory Interface ( DMC )

### 2.1 Overview

The DMC includes DDR protocol controller (PCTL) and DDR PHY which are a complete memory interface solution for DDR memory subsystems.

The PCTL SoC application bus interface supports AXI interface, with a flexible address mapper logic allow application-specific mapping of row, column, bank, bank group and rank bits to achieve industry leading high-efficiency, low-latency and high-performance from memory interface.

The DDR PHY provides control features to ease the customer implementation of digitally controlled features of the PHY such as initialization, DQS gate training, write leveling training and programmable configuration controls.

The DMC supports the following features:

- Support DDR3/DDR3L/DDR4/LPDDR2/LPDDR3
- Support up to 2 ranks and up to 4GB capacity
- Support 32-bit, 16-bit and 8-bit DDR data bus width
- Support up to 14-type address mapping
- Support up to 32-bank (including bank group)
- Support DDR burst8 only
- Support different CL/WL latency
- Support DDR3/DDR3L/DDR4/LPDDR2/LPDDR3 SW frequency change
- Support DDR4 DBI, PDA
- Support auto gated clock through DDRC and AXI low power interface
- Support auto put DDR PHY entry or exit self-refresh by DFI lower power interface
- Support auto or SW issue entry or exit clock stop/power-down/self-refresh/deep power-down/max power saving mode
- Support SW or PMU auto let DDR PHY entry or exit retention/self-refresh
- Support open, close, intelligent pre-charge paging policy
- Support Advance refresh control
- Support APB interface for PCTL and PHY software-accessible registers
- Support automatic DQS gate training and automatic write leveling training
- Support TX DLL and RX DLL adjustment

### 2.2 Block Diagram



Fig. 2-1 DMC Block Diagram

## 2.3 Function Description

### 2.3.1 PCTL

PCTL supports only one AXI Port0, it receives AXI transactions from memory schedule of interconnect. These transactions are queued internally and scheduled for access in order to the SDRAM while satisfying SDRAM protocol timing requirements. It in turn issues commands on the DFI interface to the DDR PHY block which launches and captures data to and from the SDRAM. PCTL contains the following main components:

- AXI2HIF block: This block provides the AXI interface to system level and HIF interface to DDRC block. It provides bus protocol handing, data buffering, data bus size conversion and memory burst alignment. Read is stored in a SRAM, read re-order buffer and return in order to the AXI Port.
- DDRC block: This block issues the read/write commands in order, carries out the DRAM page management, issues DRAM maintenance commands, and implement the DFI interface. Write data is stored in an SRAM until its associated command is issued to the PHY. Read data is handled by the response engine in the DDRC and is returned in order on the HIF.

### 2.3.2 DDR PHY

DDR PHY supports DDR3/DDR3L/DDR4/LPDDR2/LPDDR3 SDRAM and provides turnkey physical interface solutions for ICs requiring access to JEDEC compatible SDRAM devices. It is optimized for low power and high speed (up to 1066Mbps for LPDDR2 and up to 1600Mbps for DDR3/DDR3L/LPDDR3/DDR4) applications with robust timing and small silicon area in 28nm process. It supports all JEDEC DDR3/DDR3L/DDR4/LPDDR2/LPDDR3 SDRAM components in the market. The PHY components contain DDR specialized functional and utility SSTL and HSUL I/Os up to 1600MHz in 28nm, critical timing synchronization module (TSM) and a low power/jitter DLLs with programmable fine-grain control for any SDRAM interface.

## 2.4 Register Description

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

### 2.4.1 Registers Summary

| Name           | Offset | Size | Reset Value | Description                                 |
|----------------|--------|------|-------------|---------------------------------------------|
| DDRC_MSTR      | 0x0000 | W    | 0x03040001  | Master Register 0                           |
| DDRC_STAT      | 0x0004 | W    | 0x00000000  | Operating Mode Status Register              |
| DDRC_MRCTRL0   | 0x0010 | W    | 0x00000000  | Mode Register Read/Write Control Register 0 |
| DDRC_MRCTRL1   | 0x0014 | W    | 0x00000000  | Mode Register Read/Write Control Register 1 |
| DDRC_MRSTAT    | 0x0018 | W    | 0x00000000  | Mode Register Read/Write Status Register    |
| DDRC_MRCTRL2   | 0x001c | W    | 0x00000000  | Mode Register Read/Write Control Register 2 |
| DDRC_DERATEEN  | 0x0020 | W    | 0x00000000  | Temperature Derate Enable Register          |
| DDRC_DERATEINT | 0x0024 | W    | 0x00800000  | Temperature Derate Interval Registers       |

| <b>Name</b>            | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>                              |
|------------------------|---------------|-------------|--------------------|-------------------------------------------------|
| <u>DDRC_PWRCTL</u>     | 0x0030        | W           | 0x00000000         | Lower Power Control Register                    |
| <u>DDRC_PWRTMG</u>     | 0x0034        | W           | 0x00402010         | Lower Power Timing Register                     |
| <u>DDRC_HWLPCtl</u>    | 0x0038        | W           | 0x00000003         | Hardware Lower Power Control Register           |
| <u>DDRC_HWFFCCTL</u>   | 0x003c        | W           | 0x00000010         | Hardware Fast Frequency Change Control Register |
| <u>DDRC_HWFFCSTAT</u>  | 0x0040        | W           | 0x00000000         | Hardware Fast Frequency Change Status Register  |
| <u>DDRC_RFSHCTL0</u>   | 0x0050        | W           | 0x00210000         | Refresh Control Register                        |
| <u>DDRC_RFSHCTL1</u>   | 0x0054        | W           | 0x00000000         | Refresh Control Register 1                      |
| <u>DDRC_RFSHCTL3</u>   | 0x0060        | W           | 0x00000000         | Refresh Control Register 3                      |
| <u>DDRC_RFSHTMG</u>    | 0x0064        | W           | 0x0062008c         | Refresh Timing Register                         |
| <u>DDRC_CRCPARCTL0</u> | 0x00c0        | W           | 0x00000000         | CRC Parity Control Register 0                   |
| <u>DDRC_CRCPARCTL1</u> | 0x00c4        | W           | 0x00001000         | CRC Parity Control Register 1                   |
| <u>DDRC_CRCPARSTAT</u> | 0x00cc        | W           | 0x00000000         | CRC Parity Status Register                      |
| <u>DDRC_INIT0</u>      | 0x00d0        | W           | 0x0002004e         | SDRAM Initialization Register 0                 |
| <u>DDRC_INIT1</u>      | 0x00d4        | W           | 0x00000000         | SDRAM Initialization Register 1                 |
| <u>DDRC_INIT2</u>      | 0x00d8        | W           | 0x00000d05         | SDRAM Initialization Register 2                 |
| <u>DDRC_INIT3</u>      | 0x00dc        | W           | 0x00000510         | SDRAM Initialization Register 3                 |
| <u>DDRC_INIT4</u>      | 0x00e0        | W           | 0x00000000         | SDRAM Initialization Register 4                 |
| <u>DDRC_INIT5</u>      | 0x00e4        | W           | 0x00100004         | SDRAM Initialization Register 5                 |
| <u>DDRC_INIT6</u>      | 0x00e8        | W           | 0x00000000         | SDRAM Initialization Register 6                 |
| <u>DDRC_INIT7</u>      | 0x00ec        | W           | 0x00000000         | SDRAM Initialization Register 7                 |
| <u>DDRC_DIMMCTL</u>    | 0x00f0        | W           | 0x00000000         | DIMM Control Register                           |
| <u>DDRC_RANKCTL</u>    | 0x00f4        | W           | 0x0000066f         | Rank Control Register                           |
| <u>DDRC_DRAMTMG0</u>   | 0x0100        | W           | 0x0f101b0f         | SDRAM Timing Register 0                         |
| <u>DDRC_DRAMTMG1</u>   | 0x0104        | W           | 0x00080414         | SDRAM Timing Register 1                         |
| <u>DDRC_DRAMTMG2</u>   | 0x0108        | W           | 0x0305060d         | SDRAM Timing Register 2                         |
| <u>DDRC_DRAMTMG3</u>   | 0x010c        | W           | 0x0050400c         | SDRAM Timing Register 3                         |
| <u>DDRC_DRAMTMG4</u>   | 0x0110        | W           | 0x05040405         | SDRAM Timing Register 4                         |
| <u>DDRC_DRAMTMG5</u>   | 0x0114        | W           | 0x05050403         | SDRAM Timing Register 5                         |
| <u>DDRC_DRAMTMG6</u>   | 0x0118        | W           | 0x02020005         | SDRAM Timing Register 6                         |

| <b>Name</b>            | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>                       |
|------------------------|---------------|-------------|--------------------|------------------------------------------|
| <u>DDRC_DRAMTMG7</u>   | 0x011c        | W           | 0x00000202         | SDRAM Timing Register 7                  |
| <u>DDRC_DRAMTMG8</u>   | 0x0120        | W           | 0x03034405         | SDRAM Timing Register 8                  |
| <u>DDRC_DRAMTMG9</u>   | 0x0124        | W           | 0x0004040d         | SDRAM Timing Register 9                  |
| <u>DDRC_DRAMTMG10</u>  | 0x0128        | W           | 0x001c180a         | SDRAM Timing Register 10                 |
| <u>DDRC_DRAMTMG11</u>  | 0x012c        | W           | 0x440c021c         | SDRAM Timing Register 11                 |
| <u>DDRC_DRAMTMG12</u>  | 0x0130        | W           | 0x00020010         | SDRAM Timing Register 12                 |
| <u>DDRC_DRAMTMG13</u>  | 0x0134        | W           | 0x1c200004         | SDRAM Timing Register 13                 |
| <u>DDRC_DRAMTMG14</u>  | 0x0138        | W           | 0x000000a0         | SDRAM Timing Register 14                 |
| <u>DDRC_DRAMTMG15</u>  | 0x013c        | W           | 0x00000000         | SDRAM Timing Register 15                 |
| <u>DDRC_DRAMTMG17</u>  | 0x0144        | W           | 0x00000000         | SDRAM Timing Register 17                 |
| <u>DDRC_ZQCTL0</u>     | 0x0180        | W           | 0x02000040         | ZQ Control Register 0                    |
| <u>DDRC_ZQCTL1</u>     | 0x0184        | W           | 0x02000100         | ZQ Control Register 1                    |
| <u>DDRC_ZQCTL2</u>     | 0x0188        | W           | 0x00000000         | ZQ Control Register 2                    |
| <u>DDRC_ZQSTAT</u>     | 0x018c        | W           | 0x00000000         | ZQ Status Register                       |
| <u>DDRC_DFITMG0</u>    | 0x0190        | W           | 0x07020002         | DFI Timing Register 0                    |
| <u>DDRC_DFITMG1</u>    | 0x0194        | W           | 0x00000404         | DFI Timing Register 1                    |
| <u>DDRC_DFILPCFG0</u>  | 0x0198        | W           | 0x07000000         | DFI Lower Power Configuration Register 0 |
| <u>DDRC_DFILPCFG1</u>  | 0x019c        | W           | 0x00000000         | DFI Lower Power Configuration Register 1 |
| <u>DDRC_DFIUPD0</u>    | 0x01a0        | W           | 0x00400003         | DFI Update Register 0                    |
| <u>DDRC_DFIUPD1</u>    | 0x01a4        | W           | 0x00000001         | DFI Update Register 1                    |
| <u>DDRC_DFIUPD2</u>    | 0x01a8        | W           | 0x00000001         | DFI Update Register 2                    |
| <u>DDRC_DFIMISC</u>    | 0x01b0        | W           | 0x00000001         | DFI Miscellaneous Control Register       |
| <u>DDRC_DFITMG2</u>    | 0x01b4        | W           | 0x00000202         | DFI Timing Register 2                    |
| <u>DDRC_DFITMG3</u>    | 0x01b8        | W           | 0x00000000         | DFI Timing Register 3                    |
| <u>DDRC_DFISTAT</u>    | 0x01bc        | W           | 0x00000000         | DFI Status Register                      |
| <u>DDRC_DBICTL</u>     | 0x01c0        | W           | 0x00000001         | DM/DBI Control Register                  |
| <u>DDRC_DFIPHYMSTR</u> | 0x01c4        | W           | 0x00000001         | DFI PHY Master                           |
| <u>DDRC_ADDRMAP0</u>   | 0x0200        | W           | 0x00000000         | Address Map Register 0                   |
| <u>DDRC_ADDRMAP1</u>   | 0x0204        | W           | 0x00000000         | Address Map Register 1                   |
| <u>DDRC_ADDRMAP2</u>   | 0x0208        | W           | 0x00000000         | Address Map Register 2                   |
| <u>DDRC_ADDRMAP3</u>   | 0x020c        | W           | 0x00000000         | Address Map Register 3                   |
| <u>DDRC_ADDRMAP4</u>   | 0x0210        | W           | 0x00000000         | Address Map Register 4                   |
| <u>DDRC_ADDRMAP5</u>   | 0x0214        | W           | 0x00000000         | Address Map Register 5                   |
| <u>DDRC_ADDRMAP6</u>   | 0x0218        | W           | 0x00000000         | Address Map Register 6                   |

| <b>Name</b>            | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>                           |
|------------------------|---------------|-------------|--------------------|----------------------------------------------|
| <u>DDRC_ADDRMAP7</u>   | 0x021c        | W           | 0x00000000         | Address Map Register 7                       |
| <u>DDRC_ADDRMAP8</u>   | 0x0220        | W           | 0x00000000         | Address Map Register 8                       |
| <u>DDRC_ADDRMAP9</u>   | 0x0224        | W           | 0x00000000         | Address Map Register 9                       |
| <u>DDRC_ADDRMAP10</u>  | 0x0228        | W           | 0x00000000         | Address Map Register 10                      |
| <u>DDRC_ADDRMAP11</u>  | 0x022c        | W           | 0x00000000         | Address Map Register 11                      |
| <u>DDRC_ODTCFG</u>     | 0x0240        | W           | 0x04000400         | ODT Configuration Register                   |
| <u>DDRC_ODTMAP</u>     | 0x0244        | W           | 0x00002211         | ODT/Rank Map Register                        |
| <u>DDRC_SCHED</u>      | 0x0250        | W           | 0x00000804         | Scheduler Control Register                   |
| <u>DDRC_SCHED1</u>     | 0x0254        | W           | 0x00000000         | Scheduler Control Register 1                 |
| <u>DDRC_PERFLPR1</u>   | 0x0264        | W           | 0x0f00007f         | Low Priority Read CAM Register 1             |
| <u>DDRC_PERFWR1</u>    | 0x026c        | W           | 0x0f00007f         | Write CAM Register 1                         |
| <u>DDRC_DBG0</u>       | 0x0300        | W           | 0x00000000         | Debug Register 0                             |
| <u>DDRC_DBG1</u>       | 0x0304        | W           | 0x00000000         | Debug Register 1                             |
| <u>DDRC_DBGCAM</u>     | 0x0308        | W           | 0x00000000         | CAM Debug Register                           |
| <u>DDRC_DBGCM</u>      | 0x030c        | W           | 0x00000000         | Command Debug Register                       |
| <u>DDRC_DBGSTAT</u>    | 0x0310        | W           | 0x00000000         | Status Debug Register                        |
| <u>DDRC_SWCTL</u>      | 0x0320        | W           | 0x00000001         | Software Register Programming Control Enable |
| <u>DDRC_SWSTAT</u>     | 0x0324        | W           | 0x00000001         | Software Register Programming Control Status |
| <u>DDRC_POISONCFG</u>  | 0x036c        | W           | 0x00110011         | AXI Poison Configuration Register            |
| <u>DDRC_POISONSTAT</u> | 0x0370        | W           | 0x00000000         | AXI Poison Status Register                   |
| <u>DDRC_PSTAT</u>      | 0x03fc        | W           | 0x00000000         | Port Status Register                         |
| <u>DDRC_PCCFG</u>      | 0x0400        | W           | 0x00000000         | Port Common Configuration Register           |
| <u>DDRC_PCFGR_0</u>    | 0x0404        | W           | 0x00000000         | Port 0 Configuration Read Register           |
| <u>DDRC_PCFGW_0</u>    | 0x0408        | W           | 0x00004000         | Port 0 Configuration Write Register          |
| <u>DDRC_PCTRL_0</u>    | 0x0490        | W           | 0x00000000         | Port 0 Control Register                      |

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

| <b>Name</b>        | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>  |
|--------------------|---------------|-------------|--------------------|---------------------|
| <u>DDRPHY_REG0</u> | 0x0000        | W           | 0x000000ff         | DDR PHY register 00 |
| <u>DDRPHY_REG1</u> | 0x0004        | W           | 0x00000008         | DDR PHY register 01 |
| <u>DDRPHY_REG2</u> | 0x0008        | W           | 0x00000000         | DDR PHY register 02 |
| <u>DDRPHY_REG3</u> | 0x000c        | W           | 0x00000022         | DDR PHY register 03 |
| <u>DDRPHY_REG4</u> | 0x0010        | W           | 0x00000022         | DDR PHY register 04 |

| <b>Name</b>         | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>  |
|---------------------|---------------|-------------|--------------------|---------------------|
| <u>DDRPHY_REG5</u>  | 0x0014        | W           | 0x00000000         | DDR PHY register 05 |
| <u>DDRPHY_REG6</u>  | 0x0018        | W           | 0x00000002         | DDR PHY register 06 |
| <u>DDRPHY_REG9</u>  | 0x0024        | W           | 0x00000000         | DDR PHY register 09 |
| <u>DDRPHY_REGA</u>  | 0x0028        | W           | 0x00000000         | DDR PHY register 0A |
| <u>DDRPHY_REGB</u>  | 0x002c        | W           | 0x00000000         | DDR PHY register 0B |
| <u>DDRPHY_REGC</u>  | 0x0030        | W           | 0x00000000         | DDR PHY register 0C |
| <u>DDRPHY_REG11</u> | 0x0044        | W           | 0x00000014         | DDR PHY register 11 |
| <u>DDRPHY_REG12</u> | 0x0048        | W           | 0x000000a2         | DDR PHY register 12 |
| <u>DDRPHY_REG13</u> | 0x004c        | W           | 0x0000000c         | DDR PHY register 13 |
| <u>DDRPHY_REG14</u> | 0x0050        | W           | 0x00000008         | DDR PHY register 14 |
| <u>DDRPHY_REG15</u> | 0x0054        | W           | 0x00000020         | DDR PHY register 15 |
| <u>DDRPHY_REG16</u> | 0x0058        | W           | 0x00000014         | DDR PHY register 16 |
| <u>DDRPHY_REG17</u> | 0x005c        | W           | 0x00000044         | DDR PHY register 17 |
| <u>DDRPHY_REG18</u> | 0x0060        | W           | 0x00000014         | DDR PHY register 18 |
| <u>DDRPHY_REG1B</u> | 0x006c        | W           | 0x00000000         | DDR PHY register 1B |
| <u>DDRPHY_REG1F</u> | 0x007c        | W           | 0x00000030         | DDR PHY register 1F |
| <u>DDRPHY_REG20</u> | 0x0080        | W           | 0x00000014         | DDR PHY register 20 |
| <u>DDRPHY_REG21</u> | 0x0084        | W           | 0x00000004         | DDR PHY register 21 |
| <u>DDRPHY_REG22</u> | 0x0088        | W           | 0x00000002         | DDR PHY register 22 |
| <u>DDRPHY_REG26</u> | 0x0098        | W           | 0x0000000c         | DDR PHY register 26 |
| <u>DDRPHY_REG27</u> | 0x009c        | W           | 0x00000000         | DDR PHY register 27 |
| <u>DDRPHY_REG28</u> | 0x00a0        | W           | 0x00000001         | DDR PHY register 28 |
| <u>DDRPHY_REG29</u> | 0x00a4        | W           | 0x00000002         | DDR PHY register 29 |
| <u>DDRPHY_REG2B</u> | 0x00ac        | W           | 0x00000081         | DDR PHY register 2B |
| <u>DDRPHY_REG2C</u> | 0x00b0        | W           | 0x00000000         | DDR PHY register 2C |
| <u>DDRPHY_REG2D</u> | 0x00b4        | W           | 0x00000000         | DDR PHY register 2D |
| <u>DDRPHY_REG2E</u> | 0x00b8        | W           | 0x00000004         | DDR PHY register 2E |
| <u>DDRPHY_REG2F</u> | 0x00bc        | W           | 0x00000014         | DDR PHY register 2F |
| <u>DDRPHY_REG30</u> | 0x00c0        | W           | 0x00000014         | DDR PHY register 30 |
| <u>DDRPHY_REG31</u> | 0x00c4        | W           | 0x00000004         | DDR PHY register 31 |
| <u>DDRPHY_REG32</u> | 0x00c8        | W           | 0x00000002         | DDR PHY register 32 |
| <u>DDRPHY_REG36</u> | 0x00d8        | W           | 0x00000004         | DDR PHY register 36 |
| <u>DDRPHY_REG37</u> | 0x00dc        | W           | 0x00000000         | DDR PHY register 37 |
| <u>DDRPHY_REG38</u> | 0x00e0        | W           | 0x00000001         | DDR PHY register 38 |
| <u>DDRPHY_REG39</u> | 0x00e4        | W           | 0x00000002         | DDR PHY register 39 |
| <u>DDRPHY_REG3A</u> | 0x00e8        | W           | 0x00000001         | DDR PHY register 3A |
| <u>DDRPHY_REG3B</u> | 0x00ec        | W           | 0x00000081         | DDR PHY register 3B |
| <u>DDRPHY_REG3C</u> | 0x00f0        | W           | 0x00000000         | DDR PHY register 3C |
| <u>DDRPHY_REG3D</u> | 0x00f4        | W           | 0x00000000         | DDR PHY register 3D |
| <u>DDRPHY_REG3E</u> | 0x00f8        | W           | 0x00000004         | DDR PHY register 3E |
| <u>DDRPHY_REG3F</u> | 0x00fc        | W           | 0x00000014         | DDR PHY register 3F |
| <u>DDRPHY_REG40</u> | 0x0100        | W           | 0x00000014         | DDR PHY register 40 |
| <u>DDRPHY_REG41</u> | 0x0104        | W           | 0x00000004         | DDR PHY register 41 |

| <b>Name</b>         | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>  |
|---------------------|---------------|-------------|--------------------|---------------------|
| <u>DDRPHY_REG42</u> | 0x0108        | W           | 0x00000002         | DDR PHY register 42 |
| <u>DDRPHY_REG46</u> | 0x0118        | W           | 0x0000000c         | DDR PHY register 46 |
| <u>DDRPHY_REG47</u> | 0x011c        | W           | 0x00000000         | DDR PHY register 47 |
| <u>DDRPHY_REG48</u> | 0x0120        | W           | 0x00000001         | DDR PHY register 48 |
| <u>DDRPHY_REG49</u> | 0x0124        | W           | 0x00000002         | DDR PHY register 49 |
| <u>DDRPHY_REG4A</u> | 0x0128        | W           | 0x00000001         | DDR PHY register 4A |
| <u>DDRPHY_REG4B</u> | 0x012c        | W           | 0x00000091         | DDR PHY register 4B |
| <u>DDRPHY_REG4C</u> | 0x0130        | W           | 0x00000000         | DDR PHY register 4C |
| <u>DDRPHY_REG4D</u> | 0x0134        | W           | 0x00000000         | DDR PHY register 4D |
| <u>DDRPHY_REG4E</u> | 0x0138        | W           | 0x00000004         | DDR PHY register 4E |
| <u>DDRPHY_REG4F</u> | 0x013c        | W           | 0x00000014         | DDR PHY register 4F |
| <u>DDRPHY_REG50</u> | 0x0140        | W           | 0x00000014         | DDR PHY register 50 |
| <u>DDRPHY_REG51</u> | 0x0144        | W           | 0x00000004         | DDR PHY register 51 |
| <u>DDRPHY_REG52</u> | 0x0148        | W           | 0x00000002         | DDR PHY register 52 |
| <u>DDRPHY_REG56</u> | 0x0158        | W           | 0x0000000c         | DDR PHY register 56 |
| <u>DDRPHY_REG57</u> | 0x015c        | W           | 0x00000000         | DDR PHY register 57 |
| <u>DDRPHY_REG58</u> | 0x0160        | W           | 0x00000001         | DDR PHY register 58 |
| <u>DDRPHY_REG59</u> | 0x0164        | W           | 0x00000002         | DDR PHY register 59 |
| <u>DDRPHY_REG5A</u> | 0x0168        | W           | 0x00000001         | DDR PHY register 5A |
| <u>DDRPHY_REG5B</u> | 0x016c        | W           | 0x00000091         | DDR PHY register 5B |
| <u>DDRPHY_REG5C</u> | 0x0170        | W           | 0x00000000         | DDR PHY register 5C |
| <u>DDRPHY_REG5D</u> | 0x0174        | W           | 0x00000000         | DDR PHY register 5D |
| <u>DDRPHY_REG5E</u> | 0x0178        | W           | 0x00000004         | DDR PHY register 5E |
| <u>DDRPHY_REG5F</u> | 0x017c        | W           | 0x00000014         | DDR PHY register 5F |
| <u>DDRPHY_REG70</u> | 0x01c0        | W           | 0x00000077         | DDR PHY register 70 |
| <u>DDRPHY_REG71</u> | 0x01c4        | W           | 0x00000077         | DDR PHY register 71 |
| <u>DDRPHY_REG72</u> | 0x01c8        | W           | 0x00000077         | DDR PHY register 72 |
| <u>DDRPHY_REG73</u> | 0x01cc        | W           | 0x00000077         | DDR PHY register 73 |
| <u>DDRPHY_REG74</u> | 0x01d0        | W           | 0x00000077         | DDR PHY register 74 |
| <u>DDRPHY_REG75</u> | 0x01d4        | W           | 0x00000077         | DDR PHY register 75 |
| <u>DDRPHY_REG76</u> | 0x01d8        | W           | 0x00000077         | DDR PHY register 76 |
| <u>DDRPHY_REG77</u> | 0x01dc        | W           | 0x00000077         | DDR PHY register 77 |
| <u>DDRPHY_REG78</u> | 0x01e0        | W           | 0x00000077         | DDR PHY register 78 |
| <u>DDRPHY_REG79</u> | 0x01e4        | W           | 0x00000077         | DDR PHY register 79 |
| <u>DDRPHY_REG7A</u> | 0x01e8        | W           | 0x00000007         | DDR PHY register 7A |
| <u>DDRPHY_REG7B</u> | 0x01ec        | W           | 0x00000077         | DDR PHY register 7B |
| <u>DDRPHY_REG7C</u> | 0x01f0        | W           | 0x00000077         | DDR PHY register 7C |
| <u>DDRPHY_REG7D</u> | 0x01f4        | W           | 0x00000077         | DDR PHY register 7D |
| <u>DDRPHY_REG7E</u> | 0x01f8        | W           | 0x00000077         | DDR PHY register 7E |
| <u>DDRPHY_REG7F</u> | 0x01fc        | W           | 0x00000077         | DDR PHY register 7F |
| <u>DDRPHY_REG80</u> | 0x0200        | W           | 0x00000077         | DDR PHY register 80 |
| <u>DDRPHY_REG81</u> | 0x0204        | W           | 0x00000077         | DDR PHY register 81 |
| <u>DDRPHY_REG82</u> | 0x0208        | W           | 0x00000077         | DDR PHY register 82 |

| <b>Name</b>         | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>  |
|---------------------|---------------|-------------|--------------------|---------------------|
| <u>DDRPHY_REG83</u> | 0x020c        | W           | 0x00000077         | DDR PHY register 83 |
| <u>DDRPHY_REG84</u> | 0x0210        | W           | 0x00000077         | DDR PHY register 84 |
| <u>DDRPHY_REG85</u> | 0x0214        | W           | 0x00000007         | DDR PHY register 85 |
| <u>DDRPHY_REG86</u> | 0x0218        | W           | 0x00000077         | DDR PHY register 86 |
| <u>DDRPHY_REG87</u> | 0x021c        | W           | 0x00000077         | DDR PHY register 87 |
| <u>DDRPHY_REG88</u> | 0x0220        | W           | 0x00000077         | DDR PHY register 88 |
| <u>DDRPHY_REG89</u> | 0x0224        | W           | 0x00000077         | DDR PHY register 89 |
| <u>DDRPHY_REG8A</u> | 0x0228        | W           | 0x00000077         | DDR PHY register 8A |
| <u>DDRPHY_REG8B</u> | 0x022c        | W           | 0x00000077         | DDR PHY register 8B |
| <u>DDRPHY_REG8C</u> | 0x0230        | W           | 0x00000077         | DDR PHY register 8C |
| <u>DDRPHY_REG8D</u> | 0x0234        | W           | 0x00000077         | DDR PHY register 8D |
| <u>DDRPHY_REG8E</u> | 0x0238        | W           | 0x00000077         | DDR PHY register 8E |
| <u>DDRPHY_REG8F</u> | 0x023c        | W           | 0x00000077         | DDR PHY register 8F |
| <u>DDRPHY_REG90</u> | 0x0240        | W           | 0x00000007         | DDR PHY register 90 |
| <u>DDRPHY_REG91</u> | 0x0244        | W           | 0x00000077         | DDR PHY register 91 |
| <u>DDRPHY_REG92</u> | 0x0248        | W           | 0x00000077         | DDR PHY register 92 |
| <u>DDRPHY_REG93</u> | 0x024c        | W           | 0x00000077         | DDR PHY register 93 |
| <u>DDRPHY_REG94</u> | 0x0250        | W           | 0x00000077         | DDR PHY register 94 |
| <u>DDRPHY_REG95</u> | 0x0254        | W           | 0x00000077         | DDR PHY register 95 |
| <u>DDRPHY_REG96</u> | 0x0258        | W           | 0x00000077         | DDR PHY register 96 |
| <u>DDRPHY_REG97</u> | 0x025c        | W           | 0x00000077         | DDR PHY register 97 |
| <u>DDRPHY_REG98</u> | 0x0260        | W           | 0x00000077         | DDR PHY register 98 |
| <u>DDRPHY_REG99</u> | 0x0264        | W           | 0x00000077         | DDR PHY register 99 |
| <u>DDRPHY_REG9A</u> | 0x0268        | W           | 0x00000077         | DDR PHY register 9A |
| <u>DDRPHY_REG9B</u> | 0x026c        | W           | 0x00000007         | DDR PHY register 9B |
| <u>DDRPHY_REGA3</u> | 0x028c        | W           | 0x00000030         | DDR PHY register A3 |
| <u>DDRPHY_REGAE</u> | 0x02b8        | W           | 0x00000000         | DDR PHY register AE |
| <u>DDRPHY_REGB0</u> | 0x02c0        | W           | 0x00000077         | DDR PHY register B0 |
| <u>DDRPHY_REGB1</u> | 0x02c4        | W           | 0x00000077         | DDR PHY register B1 |
| <u>DDRPHY_REGB2</u> | 0x02c8        | W           | 0x00000077         | DDR PHY register B2 |
| <u>DDRPHY_REGB3</u> | 0x02cc        | W           | 0x00000077         | DDR PHY register B3 |
| <u>DDRPHY_REGB4</u> | 0x02d0        | W           | 0x00000077         | DDR PHY register B4 |
| <u>DDRPHY_REGB5</u> | 0x02d4        | W           | 0x00000077         | DDR PHY register B5 |
| <u>DDRPHY_REGB6</u> | 0x02d8        | W           | 0x00000077         | DDR PHY register B6 |
| <u>DDRPHY_REGB7</u> | 0x02dc        | W           | 0x00000077         | DDR PHY register B7 |
| <u>DDRPHY_REGB8</u> | 0x02e0        | W           | 0x00000077         | DDR PHY register B8 |
| <u>DDRPHY_REGB9</u> | 0x02e4        | W           | 0x00000077         | DDR PHY register B9 |
| <u>DDRPHY_REGBA</u> | 0x02e8        | W           | 0x00000077         | DDR PHY register BA |
| <u>DDRPHY_REGBB</u> | 0x02ec        | W           | 0x00000077         | DDR PHY register BB |
| <u>DDRPHY_REGBC</u> | 0x02f0        | W           | 0x00000077         | DDR PHY register BC |
| <u>DDRPHY_REGBD</u> | 0x02f4        | W           | 0x00000077         | DDR PHY register BD |
| <u>DDRPHY_REGBE</u> | 0x02f8        | W           | 0x00000077         | DDR PHY register BE |
| <u>DDRPHY_REGC0</u> | 0x0300        | W           | 0x00000077         | DDR PHY register C0 |

| <b>Name</b>         | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>  |
|---------------------|---------------|-------------|--------------------|---------------------|
| <u>DDRPHY_REGC1</u> | 0x0304        | W           | 0x00000077         | DDR PHY register C1 |
| <u>DDRPHY_REGC2</u> | 0x0308        | W           | 0x00000077         | DDR PHY register C2 |
| <u>DDRPHY_REGC3</u> | 0x030c        | W           | 0x00000077         | DDR PHY register C3 |
| <u>DDRPHY_REGC4</u> | 0x0310        | W           | 0x00000077         | DDR PHY register C4 |
| <u>DDRPHY_REGC5</u> | 0x0314        | W           | 0x00000077         | DDR PHY register C5 |
| <u>DDRPHY_REGC6</u> | 0x0318        | W           | 0x00000077         | DDR PHY register C6 |
| <u>DDRPHY_REGC7</u> | 0x031c        | W           | 0x00000077         | DDR PHY register C7 |
| <u>DDRPHY_REGC8</u> | 0x0320        | W           | 0x00000077         | DDR PHY register C8 |
| <u>DDRPHY_REGC9</u> | 0x0324        | W           | 0x00000077         | DDR PHY register C9 |
| <u>DDRPHY_REGCA</u> | 0x0328        | W           | 0x00000007         | DDR PHY register CA |
| <u>DDRPHY_REGCB</u> | 0x032c        | W           | 0x00000077         | DDR PHY register CB |
| <u>DDRPHY_REGCC</u> | 0x0330        | W           | 0x00000077         | DDR PHY register CC |
| <u>DDRPHY_REGCD</u> | 0x0334        | W           | 0x00000077         | DDR PHY register CD |
| <u>DDRPHY_REGCE</u> | 0x0338        | W           | 0x00000077         | DDR PHY register CE |
| <u>DDRPHY_REGCF</u> | 0x033c        | W           | 0x00000077         | DDR PHY register CF |
| <u>DDRPHY_REGD0</u> | 0x0340        | W           | 0x00000077         | DDR PHY register D0 |
| <u>DDRPHY_REGD1</u> | 0x0344        | W           | 0x00000077         | DDR PHY register D1 |
| <u>DDRPHY_REGD2</u> | 0x0348        | W           | 0x00000077         | DDR PHY register D2 |
| <u>DDRPHY_REGD3</u> | 0x034c        | W           | 0x00000077         | DDR PHY register D3 |
| <u>DDRPHY_REGD4</u> | 0x0350        | W           | 0x00000077         | DDR PHY register D4 |
| <u>DDRPHY_REGD5</u> | 0x0354        | W           | 0x00000007         | DDR PHY register D5 |
| <u>DDRPHY_REGD6</u> | 0x0358        | W           | 0x00000077         | DDR PHY register D6 |
| <u>DDRPHY_REGD7</u> | 0x035c        | W           | 0x00000077         | DDR PHY register D7 |
| <u>DDRPHY_REGD8</u> | 0x0360        | W           | 0x00000077         | DDR PHY register D8 |
| <u>DDRPHY_REGD9</u> | 0x0364        | W           | 0x00000077         | DDR PHY register D9 |
| <u>DDRPHY_REGDA</u> | 0x0368        | W           | 0x00000077         | DDR PHY register DA |
| <u>DDRPHY_REGDB</u> | 0x036c        | W           | 0x00000077         | DDR PHY register DB |
| <u>DDRPHY_REGDC</u> | 0x0370        | W           | 0x00000077         | DDR PHY register DC |
| <u>DDRPHY_REGDD</u> | 0x0374        | W           | 0x00000077         | DDR PHY register DD |
| <u>DDRPHY_REGDE</u> | 0x0378        | W           | 0x00000070         | DDR PHY register DE |
| <u>DDRPHY_REGDF</u> | 0x037c        | W           | 0x00000077         | DDR PHY register DF |
| <u>DDRPHY_REGE0</u> | 0x0380        | W           | 0x00000007         | DDR PHY register E0 |
| <u>DDRPHY_REGE1</u> | 0x0384        | W           | 0x00000077         | DDR PHY register E1 |
| <u>DDRPHY_REGE2</u> | 0x0388        | W           | 0x00000077         | DDR PHY register E2 |
| <u>DDRPHY_REGE3</u> | 0x038c        | W           | 0x00000077         | DDR PHY register E3 |
| <u>DDRPHY_REGE4</u> | 0x0390        | W           | 0x00000077         | DDR PHY register E4 |
| <u>DDRPHY_REGE5</u> | 0x0394        | W           | 0x00000077         | DDR PHY register E5 |
| <u>DDRPHY_REGE6</u> | 0x0398        | W           | 0x00000077         | DDR PHY register E6 |
| <u>DDRPHY_REGE7</u> | 0x039c        | W           | 0x00000077         | DDR PHY register E7 |
| <u>DDRPHY_REGE8</u> | 0x03a0        | W           | 0x00000077         | DDR PHY register E8 |
| <u>DDRPHY_REGE9</u> | 0x03a4        | W           | 0x00000077         | DDR PHY register E9 |
| <u>DDRPHY_REGEA</u> | 0x03a8        | W           | 0x00000077         | DDR PHY register EA |
| <u>DDRPHY_REGEB</u> | 0x03ac        | W           | 0x00000007         | DDR PHY register EB |

| Name         | Offset | Size | Reset Value | Description         |
|--------------|--------|------|-------------|---------------------|
| DDRPHY_REGEC | 0x03b0 | W    | 0x00000000  | DDR PHY register EC |
| DDRPHY_REGF0 | 0x03c0 | W    | 0x00000000  | DDR PHY register F0 |
| DDRPHY_REGF1 | 0x03c4 | W    | 0x00000000  | DDR PHY register F1 |
| DDRPHY_REGF2 | 0x03c8 | W    | 0x00000000  | DDR PHY register F2 |
| DDRPHY_REGF3 | 0x03cc | W    | 0x00000000  | DDR PHY register F3 |
| DDRPHY_REGF4 | 0x03d0 | W    | 0x00000000  | DDR PHY register F4 |
| DDRPHY_REGFA | 0x03e8 | W    | 0x00000000  | DDR PHY register FA |
| DDRPHY_REGFB | 0x03ec | W    | 0x00000000  | DDR PHY register FB |
| DDRPHY_REGFC | 0x03f0 | W    | 0x00000000  | DDR PHY register FC |
| DDRPHY_REGFD | 0x03f4 | W    | 0x00000000  | DDR PHY register FD |
| DDRPHY_REGFE | 0x03f8 | W    | 0x00000000  | DDR PHY register FE |
| DDRPHY_REGFF | 0x03fc | W    | 0x00000000  | DDR PHY register FF |

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

## 2.4.2 Detail Register Description

### DDRC\_MSTR

Address: Operational Base + offset (0x0000)

| Bit   | Attr | Reset Value | Description                                                                                                                                     |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30 | RW   | 0x0         | device_config<br>Configuration of device used<br>00: x4 device<br>01: x8 device<br>10: x16 device<br>11: x32 device<br>Programming Mode: Static |
| 29    | RW   | 0x0         | frequency_mode<br>Choose which register are used<br>0: original registers<br>1: FREQ1 registers<br>Programming Mode: Quasi-dynamic Group 2      |
| 28:26 | RO   | 0x0         | reserved                                                                                                                                        |
| 25:24 | RW   | 0x3         | active_ranks<br>01: One Rank<br>11: Two Ranks<br>Programming Mode: Static                                                                       |
| 23    | RO   | 0x0         | reserved                                                                                                                                        |
| 22    | RW   | 0x0         | frequency_ratio<br>selects the frequency ratio<br>0: 1:2 mode<br>1: 1:1 mode<br>Programming Mode: Static                                        |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 21:20      | RW          | 0x0                | active_logical_ranks<br>Number of logical ranks for DDR4 3DS<br>0: monolithic (no stack)<br>1: 2H stack<br>2: 4H stack<br>3: 8H stack<br>Programming Mode: Static               |
| 19:16      | RW          | 0x4                | burst_rdwr<br>SDRAM burst length used:<br>0001: burst length of 2<br>0010: burst length of 4<br>0100: burst length of 8<br>1000: burst length of 16<br>Programming Mode: Static |
| 15         | RW          | 0x0                | dll_off_mode<br>1: dll-off mode for lower frequency operation<br>0: dll-on mode for normal frequency operation<br>Programming Mode: Quasi-dynamic Group 2                       |
| 14         | RO          | 0x0                | reserved                                                                                                                                                                        |
| 13:12      | RW          | 0x0                | data_bus_width<br>00: full DQ bus width to SDRAM<br>01: half DQ bus width to SDRAM<br>1x: reserved<br>Programming Mode: Static                                                  |
| 11         | RW          | 0x0                | geardown_mode<br>1: enable geardown mode<br>0: normal mode<br>Programming Mode: Quasi-dynamic Group 2                                                                           |
| 10         | RW          | 0x0                | en_2t_timing_mode<br>1: use 2T timing<br>0: use 1T timing<br>Programming Mode: Static                                                                                           |
| 9          | RW          | 0x0                | burstchop<br>1: enable burst-chop<br>Programming Mode: Static                                                                                                                   |
| 8          | RW          | 0x0                | burst_mode<br>0: sequential burst mode<br>1: interleaved burst mode<br>Programming Mode: Static                                                                                 |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                        |
| 5          | RW          | 0x0                | lpddr4<br>1: LPDDR4<br>0: Non-LPDDR4<br>Programming Mode: Static                                                                                                                |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------|
| 4          | RW          | 0x0                | ddr4<br>1: DDR4<br>0: Non-DDR4<br>Programming Mode: Static             |
| 3          | RW          | 0x0                | lpddr3<br>1: LPDDR3<br>0: Non-LPDDR3<br>Programming Mode: Static       |
| 2          | RW          | 0x0                | lpddr2<br>1: LPDDR2<br>0: Non-LPDDR2<br>Programming Mode: Static       |
| 1          | RW          | 0x0                | mobile<br>1: Mobile/LPDDR<br>0: Non-Mobile<br>Programming Mode: Static |
| 0          | RW          | 0x1                | ddr3<br>1: DDR3<br>0: Non-DDR3<br>Programming Mode: Static             |

**DDRC\_STAT**

Address: Operational Base + offset (0x0004)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:13      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                  |
| 12         | RO          | 0x0                | selfref_cam_not_empty<br>Self refresh with CAMs not empty. Set to 1 when Self Refresh is entered but CAMs are not drained. Cleared after exiting Self Refresh<br>Programming Mode: Dynamic                                                                                                                                                |
| 11:10      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                  |
| 9:8        | RO          | 0x0                | selfref_state<br>Self refresh state. This indicates self refresh or self refresh power down state for LPDDR4. This register is used for frequency change and MRR/MRW access during self refresh.<br>00:SDRAM is not in Self Refresh.<br>01:Self refresh 1<br>10:Self refresh power down<br>11:Self refresh 2<br>Programming Mode: Dynamic |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5:4        | RO          | 0x0                | <p>selfref_type<br/>           Flags if Self Refresh (except LPDDR4) or SR-Powerdown (LPDDR4) is entered and if it was under Automatic Self Refresh control only or not.</p> <p>00:SDRAM is not in Self Refresh (except LPDDR4) or SR-Powerdown (LPDDR4). If retry is enabled by CRCPARCTRL1.crc_parity_retry_enable, this also indicates SRE command is still in parity error window or retry is in-progress.</p> <p>11:SDRAM is in Self Refresh (except LPDDR4) or SRPowerdown (LPDDR4), which was caused by Automatic Self Refresh only. If retry is enabled, this guarantees SRE command is executed correctly without parity error.</p> <p>10:SDRAM is in Self Refresh (except LPDDR4) or SRPowerdown (LPDDR4), which was not caused solely under Automatic Self Refresh control. It could have been caused by Hardware Low Power Interface and/or Software (PWRCTL.selfref_sw). If retry is enabled, this guarantees SRE command is executed correctly without parity error.</p> <p>01: SDRAM is in Self Refresh, which was caused by PHY Master Request.</p> <p>Programming Mode: Dynamic</p> |
| 3          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 2:0        | RO          | 0x0                | <p>operating_mode<br/>           Operating mode. This is 3-bits wide in configurations with mDDR/LPDDR2/LPDDR3/LPDDR4/DDR4 support and 2-bits in all other configurations.</p> <p>non-mDDR/LPDDR2/LPDDR3/LPDDR4 and non-DDR4 designs:<br/>           00: Init; 01:Normal; 10:Power-down; 11:Self refresh</p> <p>mDDR/LPDDR2/LPDDR3 or DDR4 designs:<br/>           000:Init; 001:Normal; 010:Power-down; 011:Self refresh;<br/>           1XX:Deep power-down / Maximum Power Saving Mode</p> <p>LPDDR4 designs:<br/>           000:Init; 001:Normal; 010:Power-down; 011:Self refresh / Self refresh power-down</p> <p>Programming Mode: Dynamic</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                |

**DDRC\_MRCTRL0**

Address: Operational Base + offset (0x0010)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RW          | 0x0                | <p>mr_wr</p> <p>Setting this register bit to 1 triggers a mode register read or write operation. When the MR operation is complete, the uMCTL2 automatically clears this bit. The other register fields of this register must be written in a separate APB transaction, before setting this mr_wr bit. It is recommended NOT to set this signal if in Init, Deep power-down or MPSM operating modes.</p> <p>Programming Mode: Dynamic</p> |
| 30         | RW          | 0x0                | <p>pba_mode</p> <p>Indicates whether PBA access is executed. When setting this bit to 1 along with setting pda_en to 1, uMCTL2 initiates PBA access instead of PDA access.</p> <p>0: Per DRAM Addressability mode; 1: Per Buffer Addressability mode</p> <p>The completion of PBA access is confirmed by MRSTAT.pda_done in the same way as PDA.</p> <p>Programming Mode: Dynamic</p>                                                     |
| 29:16      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 15:12      | RW          | 0x0                | <p>mr_addr</p> <p>Address of the mode register that is to be written to.</p> <p>0000: MR0; 0001: MR1; 0010: MR2; 0011: MR3; 0100: MR4; 0101: MR5; 0110: MR6; 0111: MR7.</p> <p>Don't Care for LPDDR2/LPDDR3/LPDDR4 (see MRCTRL1.mr_data for mode register addressing in LPDDR2/LPDDR3/LPDDR4)</p> <p>In case of DDR4, the bit[3:2] corresponds to the bank group bits.</p> <p>Programming Mode: Dynamic</p>                               |
| 11:6       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 5:4        | RW          | 0x0                | <p>mr_rank</p> <p>Controls which rank is accessed by MRCTRL0.mr_wr. Normally, it is desired to access all ranks, so all bits should be set to 1.</p> <p>0x1: select rank 0 only</p> <p>0x2: select rank 1 only</p> <p>0x3: select rank 0 and 1</p> <p>Programming Mode: Dynamic</p>                                                                                                                                                       |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3          | RW          | 0x0                | <p>sw_init_int<br/>Indicates whether Software intervention is allowed via MRCTRL0/MRCTRL1 before automatic SDRAM initialization routine or not.</p> <p>For DDR4, this bit can be used to initialize the DDR4 RCD (MR7) before automatic SDRAM initialization.</p> <p>For LPDDR4, this bit can be used to program additional mode registers before automatic SDRAM initialization if necessary.</p> <p>Note that this must be cleared to 0 after completing Software operation. Otherwise, SDRAM initialization routine will not restart.</p> <p>0: Software intervention is not allowed; 1: Software intervention is allowed</p> <p>Programming Mode: Dynamic</p> |
| 2          | RW          | 0x0                | <p>pda_en<br/>Indicates whether the mode register operation is MRS in PDA mode or not</p> <p>0: MRS; 1: MRS in Per DRAM Addressability mode</p> <p>Note that when pba_mode=1, PBA access is initiated instead of PDA access.</p> <p>Programming Mode: Dynamic</p>                                                                                                                                                                                                                                                                                                                                                                                                 |
| 1          | RW          | 0x0                | <p>mpr_en<br/>Indicates whether the mode register operation is MRS or WR/RD for MPR (only supported for DDR4)</p> <p>0: MRS; 1: WR/RD for MPR</p> <p>Programming Mode: Dynamic</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 0          | RW          | 0x0                | <p>mr_type<br/>Indicates whether the mode register operation is read or write.</p> <p>Only used for LPDDR2/LPDDR3/LPDDR4/DDR4.</p> <p>0: Write; 1: Read</p> <p>Programming Mode: Dynamic</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

**DDRC\_MRCTRL1**

Address: Operational Base + offset (0x0014)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:18      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                  |
| 17:0       | RW          | 0x00000            | <p>mr_data<br/>Mode register write data for all non-LPDDR2/non-LPDDR3/non-LPDDR4 modes.</p> <p>For LPDDR2/LPDDR3/LPDDR4, MRCTRL1[15:0] are interpreted as [15:8] MR Address</p> <p>[7:0] MR data for writes, don't care for reads. This is 18-bits wide in configurations with DDR4 support and 16-bits in all other configurations.</p> <p>Programming Mode: Dynamic</p> |

**DDRC\_MRSTAT**

Address: Operational Base + offset (0x0018)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:9       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 8          | RO          | 0x0                | <p>pda_done</p> <p>The SoC core may initiate a MR write operation in PDA/PBA mode only if this signal is low. This signal goes high when three consecutive MRS commands related to the PDA/PBA mode are issued to the SDRAM. This signal goes low when MRCTRL0.pda_en becomes 0. Therefore, it is recommended to write MRCTRL0.pda_en to 0 after this signal goes high in order to prepare to perform PDA operation next time.</p> <p>0: Indicates that mode register write operation related to PDA/PBA is in progress or has not started yet.</p> <p>1: Indicates that mode register write operation related to PDA/PBA has completed.</p> <p>Programming Mode: Dynamic</p> |
| 7:1        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 0          | RO          | 0x0                | <p>mr_wr_busy</p> <p>The SoC core may initiate a MR write operation only if this signal is low. This signal goes high in the clock after the uMCTL2 accepts the MRW/MRR request. It goes low when the MRW/MRR command is issued to the SDRAM. It is recommended not to perform MRW/MRR commands when MRSTAT.mr_wr_busy is high.</p> <p>0: Indicates that the SoC core can initiate a mode register write operation</p> <p>1: Indicates that mode register write operation is in progress</p> <p>Programming Mode: Dynamic</p>                                                                                                                                                 |

**DDRC\_MRCTRL2**

Address: Operational Base + offset (0x001c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | <p>mr_device_sel<br/>Indicates the device(s) to be selected during the MRS that happens in PDA mode. Each bit is associated with one device. For example, bit[0] corresponds to Device 0, bit[1] to Device 1 etc.</p> <p>A '1' should be programmed to indicate that the MRS command should be applied to that device.</p> <p>A '0' indicates that the MRS commands should be skipped for that device.</p> <p>Programming Mode: Dynamic</p> |

**DDRC DERATEEN**

Address: Operational Base + offset (0x0020)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:11      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 10:8       | RW          | 0x0                | <p>rc_derate_value<br/>Derate value of tRC for LPDDR4</p> <p>0: Derating uses +1.<br/>1: Derating uses +2.<br/>2: Derating uses +3.<br/>3: Derating uses +4.</p> <p>Present only in designs configured to support LPDDR4. The required number of cycles for derating can be determined by dividing 3.75ns by the core_ddrc_core_clk period, and rounding up the next integer.</p> <p>Programming Mode: Quasi-dynamic Group 2 and Group 4</p>                                                         |
| 7:4        | RW          | 0x0                | <p>derate_byte<br/>Derate byte Present only in designs configured to support LPDDR2/LPDDR3/LPDDR4</p> <p>Indicates which byte of the MRR data is used for derating.</p> <p>Programming Mode: Static</p>                                                                                                                                                                                                                                                                                              |
| 3:2        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 1          | RW          | 0x0                | <p>derate_value<br/>Derate value</p> <p>0: Derating uses +1.<br/>1: Derating uses +2.</p> <p>Present only in designs configured to support LPDDR2/LPDDR3/LPDDR4</p> <p>Set to 0 for all LPDDR2 speed grades as derating value of +1.875 ns is less than a core_ddrc_core_clk period. For LPDDR3/4, if the period of core_ddrc_core_clk is less than 1.875ns, this register field should be set to 1; otherwise it should be set to 0.</p> <p>Programming Mode: Quasi-dynamic Group 2 and Group 4</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0          | RW          | 0x0                | <p>derate_enable<br/>Enables derating<br/>0: Timing parameter derating is disabled<br/>1: Timing parameter derating is enabled using MR4 read value.<br/>Present only in designs configured to support LPDDR2/LPDDR3/LPDDR4<br/>This field must be set to 0 for non-LPDDR2/LPDDR3/LPDDR4 mode.<br/>Programming Mode: Dynamic</p> |

**DDRC DERATEINT**

Address: Operational Base + offset (0x0024)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00800000         | <p>mr4_read_interval<br/>Interval between two MR4 reads, used to derate the timing parameters.<br/>Present only in designs configured to support LPDDR2/LPDDR3/LPDDR4. This register must not be set to zero.<br/>Unit: DFI clock cycle.<br/>Programming Mode: Static</p> |

**DDRC PWRCTL**

Address: Operational Base + offset (0x0030)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:9       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                         |
| 8          | RW          | 0x0                | <p>lpddr4_sr_allowed<br/>Indicates whether transition from SR-PD to SR and back to SR-PD is allowed.<br/>This register field cannot be modified while PWRCTL.selfref_sw==1.<br/>0: SR-PD -&gt; SR -&gt; SR-PD not allowed<br/>1: SR-PD -&gt; SR -&gt; SR-PD allowed<br/>Programming Mode: Dynamic</p>            |
| 7          | RW          | 0x0                | <p>dis_cam_drain_selfref<br/>Indicates whether skipping CAM draining is allowed when entering Self-Refresh.<br/>This register field cannot be modified while PWRCTL.selfref_sw==1.<br/>0: CAMs must be empty before entering SR<br/>1: CAMs are not emptied before entering SR<br/>Programming Mode: Dynamic</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6          | RW          | 0x0                | <p>stay_in_selfref<br/>Self refresh state is an intermediate state to enter to Selfrefresh power down state or exit Self refresh power down state for LPDDR4.</p> <p>This register controls transition from the Self refresh state.<br/>1: Prohibit transition from Self refresh state<br/>0: Allow transition from Self refresh state</p> <p>Programming Mode: Dynamic</p>                                                                                                                                                                                                                                                                                   |
| 5          | RW          | 0x0                | <p>selfref_sw<br/>A value of 1 to this register causes system to move to Self Refresh state immediately, as long as it is not in INIT or DPD/MPSM operating_mode. This is referred to as Software Entry/Exit to Self Refresh.</p> <p>1: Software Entry to Self Refresh<br/>0: Software Exit from Self Refresh</p> <p>Programming Mode: Dynamic</p>                                                                                                                                                                                                                                                                                                            |
| 4          | RW          | 0x0                | <p>mpsm_en<br/>When this is 1, the uMCTL2 puts the SDRAM into maximum power saving mode when the transaction store is empty. This register must be reset to '0' to bring uMCTL2 out of maximum power saving mode.</p> <p>Present only in designs configured to support DDR4. For non-DDR4, this register should not be set to 1.</p> <p>Programming Mode: Dynamic</p>                                                                                                                                                                                                                                                                                         |
| 3          | RW          | 0x0                | <p>en_dfi_dram_clk_disable<br/>Enable the assertion of dfi_dram_clk_disable whenever a clock is not required by the SDRAM. If set to 0, dfi_dram_clk_disable is never asserted.</p> <p>Assertion of dfi_dram_clk_disable is as follows:<br/>In DDR2/DDR3, can only be asserted in Self Refresh.<br/>In DDR4, can be asserted in the Self Refresh and Maximum Power Saving Mode<br/>In mDDR/LPDDR2/LPDDR3, can be asserted in the Self Refresh, Power Down, Deep Power Down and Normal operation (Clock Stop)<br/>In LPDDR4, can be asserted in the Self Refresh Power Down, Power Down and Normal operation (Clock Stop)</p> <p>Programming Mode: Dynamic</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2          | RW          | 0x0                | <p>deeppowerdown_en</p> <p>When this is 1, uMCTL2 puts the SDRAM into deep powerdown mode when the transaction store is empty.</p> <p>This register must be reset to '0' to bring uMCTL2 out of deep power-down mode. Controller performs automatic SDRAM initialization on deep power-down exit.</p> <p>Present only in designs configured to support mDDR or LPDDR2 or LPDDR3. For non-mDDR/non-LPDDR2/nonLPDDR3, this register should not be set to 1.</p> <p>Programming Mode: Dynamic</p> |
| 1          | RW          | 0x0                | <p>powerdown_en</p> <p>If true then the uMCTL2 goes into power-down after a programmable number of cycles "maximum idle clocks before power down" PWRTMG.powerdown_to_x32).</p> <p>This register bit may be re-programmed during the course of normal operation.</p> <p>Programming Mode: Dynamic</p>                                                                                                                                                                                          |
| 0          | RW          | 0x0                | <p>selfref_en</p> <p>If true then the uMCTL2 puts the SDRAM into Self Refresh after a programmable number of cycles "maximum idle clocks before Self Refresh (PWRTMG.selfref_to_x32)". This register bit may be re-programmed during the course of normal operation.</p> <p>Programming Mode: Dynamic</p>                                                                                                                                                                                      |

**DDRC PWRTMG**

Address: Operational Base + offset (0x0034)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                              |
| 23:16      | RW          | 0x40               | <p>selfref_to_x32</p> <p>After this many clocks of the DDRC command channel being idle the uMCTL2 automatically puts the SDRAM into Self Refresh. The DDRC command channel is considered idle when there are no HIF commands outstanding. This must be enabled in the PWRCTL.selfref_en.</p> <p>Unit: Multiples of 32 DFI clocks.</p> <p>Programming Mode: Static</p> |
| 15:8       | RW          | 0x20               | <p>t_dpd_x4096</p> <p>Minimum deep power-down time.</p> <p>For mDDR, value from the JEDEC specification is 0 as mDDR exits from deep power-down mode immediately after PWRCTL.deeppowerdown_en is de-asserted.</p> <p>For LPDDR2/LPDDR3, value from the JEDEC specification is 500us.</p> <p>Unit: Multiples of 4096 DFI clocks.</p> <p>Programming Mode: Static</p>  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:5        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                        |
| 4:0        | RW          | 0x10               | <p>powerdown_to_x32<br/>After this many clocks of the DDRC command channel being idle the uMCTL2 automatically puts the SDRAM into powerdown. The DDRC command channel is considered idle when there are no HIF commands outstanding. This must be enabled in the PWRCTL.powerdown_en.</p> <p>Unit: Multiples of 32 DFI clocks<br/>Programming Mode: Static</p> |

**DDRC HWLPCTL**

Address: Operational Base + offset (0x0038)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 27:16      | RW          | 0x000              | <p>hw_lp_idle_x32<br/>Hardware idle period. The cactive_ddrc output is driven low if the DDRC command channel is idle for hw_lp_idle * 32 cycles if not in INIT or DPD/MPSM operating_mode. The DDRC command channel is considered idle when there are no HIF commands outstanding. The hardware idle function is disabled when hw_lp_idle_x32=0.</p> <p>Unit: Multiples of 32 DFI clocks.<br/>Programming Mode: Static</p> |
| 15:2       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 1          | RW          | 0x1                | <p>hw_lp_exit_idle_en<br/>When this bit is programmed to 1 the cactive_in_ddrc pin of the DDRC can be used to exit from the automatic clock stop, automatic power down or automatic self-refresh modes.<br/>Note, it will not cause exit of Self-Refresh that was caused by Hardware Low Power Interface and/or Software (PWRCTL.selfref_sw).</p> <p>Programming Mode: Static</p>                                           |
| 0          | RW          | 0x1                | <p>hw_lp_en<br/>Enable for Hardware Low Power Interface.<br/>Programming Mode: Quasi-dynamic Group 3</p>                                                                                                                                                                                                                                                                                                                    |

**DDRC HWFFCCTL**

Address: Operational Base + offset (0x003c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:7       | RO          | 0x0                | reserved                                                                                                                                                   |
| 6          | RW          | 0x0                | <p>target_vrcg<br/>Set target value of VRCG (MR13 OP[3]). This field value is used when HWFFC request has been issued.</p> <p>Programming Mode: Static</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5          | RW          | 0x0                | init_vrcg<br>Set initial value of VRCG (MR13 OP[3]). This field value is used when HWFFCCTL.hwffc_en has been changed to 11.<br>Programming Mode: Static                                                                                                                                  |
| 4          | RW          | 0x1                | init_fsp<br>Set initial value of FSP-OP (MR13 OP[7]). This field value is used when HWFFCCTL.hwffc_en has been changed to 11.<br>Programming Mode: Static                                                                                                                                 |
| 3:1        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                  |
| 0          | RW          | 0x0                | hwffc_en<br>Enable HWFFC through Hardware Low Power Interface. The other fields of this register is used only when changing this field to 11.<br>00: Disable HWFFC<br>10: Intermediate, set only when disabling HWFFC<br>11: Enable HWFFC<br>01: Not allowed<br>Programming Mode: Dynamic |

**DDRC HWFFCSTAT**

Address: Operational Base + offset (0x0040)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| 31:10      | RO          | 0x0                | reserved                                                                                                                            |
| 9          | RO          | 0x0                | current_vrcg<br>Indicates current value of VRCG (MR13 OP[3]).<br>Programming Mode: Dynamic                                          |
| 8          | RO          | 0x0                | current_fsp<br>Indicates current value of FSP-OP (MR13 OP[7]).<br>Programming Mode: Dynamic                                         |
| 7:5        | RO          | 0x0                | reserved                                                                                                                            |
| 4          | RO          | 0x0                | current_frequency<br>Indicates the current frequency.<br>0: Frequency 0/Normal<br>1: Frequency 1/FREQ1<br>Programming Mode: Dynamic |
| 3:2        | RO          | 0x0                | reserved                                                                                                                            |
| 1          | RO          | 0x0                | hwffc_operating_mode<br>Operating mode of HWFFC.<br>0: Normal<br>1: Self Refresh or SR-Powerdown<br>Programming Mode: Dynamic       |
| 0          | RO          | 0x0                | hwffc_in_progress<br>Indicates HWFFC is in progress.<br>Programming Mode: Dynamic                                                   |

**DDRC\_RFSHCTL0**

Address: Operational Base + offset (0x0050)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 23:20      | RW          | 0x2                | <p>refresh_margin<br/>Threshold value in number of DFI clock cycles before the critical refresh or page timer expires. A critical refresh is to be issued before this threshold is reached. It is recommended that this not be changed from the default value, currently shown as 0x2. It must always be less than internally used t_rfc_nom_x32. Note that, in LPDDR2/LPDDR3/LPDDR4, internally used t_rfc_nom_x32 may be equal to RFSHTMG.t_rfc_nom_x32&gt;&gt;2 if derating is enabled (DERATEEN.derate_enable=1). Otherwise, internally used t_rfc_nom_x32 will be equal to RFSHTMG.t_rfc_nom_x32.<br/>Unit: Multiples of 32 DFI clocks.</p> <p>Programming Mode: Dynamic - Refresh Related</p>                                                                                         |
| 19:17      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 16:12      | RW          | 0x10               | <p>refresh_to_x32<br/>If the refresh timer (tRFCnom, also known as tREFI) has expired at least once, but it has not expired (RFSHCTL0.refresh_burst+1) times yet, then a speculative refresh may be performed. A speculative refresh is a refresh performed at a time when refresh would be useful, but before it is absolutely required. When the SDRAM bus is idle for a period of time determined by this RFSHCTL0.refresh_to_x32 and the refresh timer has expired at least once since the last refresh, then a speculative refresh is performed. Speculative refreshes continues successively until there are no refreshes pending or until new reads or writes are issued to the uMCTL2.<br/>Unit: Multiples of 32 DFI clocks.</p> <p>Programming Mode: Dynamic - Refresh Related</p> |
| 11:9       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8:4        | RW          | 0x00               | <p>refresh_burst<br/>The programmed value + 1 is the number of refresh timeouts that is allowed to accumulate before traffic is blocked and the refreshes are forced to execute. Closing pages to perform a refresh is a one-time penalty that must be paid for each group of refreshes. Therefore, performing refreshes in a burst reduces the per-refresh penalty of these page closings. Higher numbers for RFSHCTL.refresh_burst slightly increases utilization; lower numbers decreases the worstcase latency associated with refreshes.</p> <p>0: single refresh<br/>1: burst-of-2 refresh<br/>7: burst-of-8 refresh</p> <p>For DDR2/3, the refresh is always per-rank and not perbank. The rank refresh can be accumulated over <math>8*t_{REFI}</math> cycles using the burst refresh feature. In DDR4 mode, according to Fine Granularity feature, 8 refreshes can be postponed in 1X mode, 16 refreshes in 2X mode and 32 refreshes in 4X mode. If using PHY-initiated updates, care must be taken in the setting of RFSHCTL0.refresh_burst, to ensure that tRFCmax is not violated due to a PHY-initiated update occurring shortly before a refresh burst was due. In this situation, the refresh burst will be delayed until the PHYinitiated update is complete.</p> <p>Programming Mode: Dynamic - Refresh Related</p> |
| 3          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 2          | RW          | 0x0                | <p>per_bank_refresh<br/>1: Per bank refresh; 0: All bank refresh.<br/>Per bank refresh allows traffic to flow to other banks. Per bank refresh is not supported by all LPDDR2 devices but should be supported by all LPDDR3/LPDDR4 devices.</p> <p>Programming Mode: Static</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 1:0        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

**DDRC\_RFSHCTL1**

Address: Operational Base + offset (0x0054)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                             |
| 27:16      | RW          | 0x000              | <p>refresh_timer1_start_value_x32<br/>Refresh timer start for rank 1 (only present in multi-rank configurations). This is useful in staggering the refreshes to multiple ranks to help traffic to proceed. This is explained in Refresh Controls section of architecture chapter.<br/>Unit: Multiples of 32 DFI clock cycles.</p> <p>Programming Mode: Dynamic - Refresh Related</p> |
| 15:12      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                             |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11:0       | RW          | 0x000              | <p>refresh_timer0_start_value_x32<br/>           Refresh timer start for rank 0 (only present in multi-rank configurations). This is useful in staggering the refreshes to multiple ranks to help traffic to proceed. This is explained in Refresh Controls section of architecture chapter.<br/>           Unit: Multiples of 32 DFI clock cycles.<br/>           Programming Mode: Dynamic - Refresh Related</p> |

**DDRC RFSHCTL3**

Address: Operational Base + offset (0x0060)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:7       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 6:4        | RW          | 0x0                | <p>refresh_mode<br/>           Fine Granularity Refresh Mode<br/>           000: Fixed 1x (Normal mode)<br/>           001: Fixed 2x<br/>           010: Fixed 4x<br/>           101: Enable on the fly 2x (not supported)<br/>           110: Enable on the fly 4x (not supported)<br/>           Everything else - reserved<br/>           Note: Only Fixed 1x mode is supported if RFSHCTL3.dis_auto_refresh = 1.<br/>           Note: The on-the-fly modes are not supported in this version of the uMCTL2.<br/>           Note: This must be set up while the Controller is in reset or while the Controller is in self-refresh mode. Changing this during normal operation is not allowed. Making this a dynamic register will be supported in future version of the uMCTL2.<br/>           Note: This register field has effect only if a DDR4 SDRAM device is in use (MSTR.ddr4 = 1).<br/>           Programming Mode: Quasi-dynamic Group 2</p> |
| 3:2        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 1          | RW          | 0x0                | <p>refresh_update_level<br/>           Toggle this signal (either from 0 to 1 or from 1 to 0) to indicate that the refresh register(s) have been updated.<br/>           refresh_update_level must not be toggled when the DDRC is in reset (core_ddrc_rstn = 0). The refresh register(s) are automatically updated when exiting reset.<br/>           Programming Mode: Dynamic</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0          | RW          | 0x0                | <p>dis_auto_refresh<br/>When '1', disable auto-refresh generated by the uMCTL2. When auto-refresh is disabled, the SoC core must generate refreshes using the registers DBGCMD.rankn_refresh. When dis_auto_refresh transitions from 0 to 1, any pending refreshes are immediately scheduled by the uMCTL2. If DDR4 CRC/parity retry is enabled (CRCPARCTL1.crc_parity_retry_enable = 1), disable autorefresh is not supported, and this bit must be set to '0'. (DDR4 only) If FGR mode is enabled (RFSHCTL3.refresh_mode &gt; 0), disable auto-refresh is not supported, and this bit must be set to '0'.<br/>This register field is changeable on the fly.<br/>Programming Mode: Dynamic - Refresh Related</p> |

**DDRC\_RFSHTMG**

Address: Operational Base + offset (0x0064)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------|
| 31         | RW          | 0x0                | t_rfc_nom_x1_sel<br>Specifies whether the t_rfc_nom_x1_x32 register value is x1 or x32 |
| 30:28      | RO          | 0x0                | reserved                                                                               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 27:16      | RW          | 0x062              | <p>t_rfc_nom_x1_x32<br/> tREFI: Average time interval between refreshes per rank<br/> (Specification: 7.8us for DDR2, DDR3 and DDR4. See JEDEC specification for mDDR, LPDDR2, LPDDR3 and LPDDR4).<br/> For LPDDR2/LPDDR3/LPDDR4:<br/> if using all-bank refreshes (RFSHCTL0.per_bank_refresh= 0), this register should be set to tREFIab<br/> if using per-bank refreshes (RFSHCTL0.per_bank_refresh = 1), this register should be set to tREFIpb<br/> When the controller is operating in 1:2 frequency ratio mode, program this to (tREFI/2), no rounding up.<br/> In DDR4 mode, tREFI value is different depending on the refresh mode. The user should program the appropriate value from the spec based on the value programmed in the refresh mode register.</p> <p>Note that if RFSHTMG.t_rfc_nom_x1_sel==1, RFSHTMG.t_rfc_nom_x1_x32 must be greater than RFSHTMG.t_rfc_min; if RFSHTMG.t_rfc_nom_x1_sel==0, RFSHTMG.t_rfc_nom_x1_x32*32 must be greater than RFSHTMG.t_rfc_min; RFSHTMG.t_rfc_nom_x32 must be greater than 0x1.</p> <p>Non-DDR4 or DDR4 Fixed 1x mode: RFSHTMG.t_rfc_nom_x1_x32 must be less than or equal to 0xFFE.</p> <p>DDR4 Fixed 2x mode: RFSHTMG.t_rfc_nom_x1_x32 must be less than or equal to 0x7FF.</p> <p>DDR4 Fixed 4x mode: RFSHTMG.t_rfc_nom_x1_x32 must be less than or equal to 0x3FF.</p> <p>Unit: Clocks or multiples of 32 clocks, depending on RFSHTMG.t_rfc_nom_x1_sel.</p> <p>Programming Mode: Dynamic - Refresh Related</p> |
| 15         | RW          | 0x0                | <p>lpddr3_trefbw_en<br/> Used only when LPDDR3 memory type is connected. Should only be changed when uMCTL2 is in reset. Specifies whether to use the tREFBW parameter (required by some LPDDR3 devices which comply with earlier versions of the LPDDR3 JEDEC specification) or not:<br/> 0: tREFBW parameter not used<br/> 1: tREFBW parameter used<br/> Programming Mode: Static</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 14:10      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9:0        | RW          | 0x08c              | <p>t_rfc_min<br/>tRFC (min): Minimum time from refresh to refresh or activate.<br/>t_rfc_min should be set to RoundUp(RoundUp(tRFCmin/tCK)/2).<br/>In LPDDR2/LPDDR3/LPDDR4 mode:<br/>if using all-bank refreshes, the tRFCmin value in the above equations is equal to tRFCab<br/>if using per-bank refreshes, the tRFCmin value in the above equations is equal to tRFCpb<br/>In DDR4 mode, the tRFCmin value in the above equations is different depending on the refresh mode (fixed 1X,2X,4X) and the device density. The user should program the appropriate value from the spec based on the 'refresh_mode' and the device density that is used.<br/>Unit: DFI Clocks.</p> <p>Programming Mode: Dynamic - Refresh Related</p> |

**DDRC\_CRCPARCTL0**

Address: Operational Base + offset (0x00c0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                           |
| 2          | W1C         | 0x0                | <p>dfi_alert_err_cnt_clr<br/>DFI alert error count clear. Clear bit for DFI alert error counter.<br/>Asserting this bit will clear the DFI alert error counter, CRCPARSTAT.dfi_alert_err_cnt. When the clear operation is complete, the uMCTL2 automatically clears this bit.</p> <p>Programming Mode: Dynamic</p> |
| 1          | W1C         | 0x0                | <p>dfi_alert_err_int_clr<br/>Interrupt clear bit for DFI alert error. If this bit is set, the alert error interrupt on CRCPARSTAT.dfi_alert_err_int will be cleared.<br/>When the clear operation is complete, the uMCTL2 automatically clears this bit.</p> <p>Programming Mode: Dynamic</p>                      |
| 0          | RW          | 0x0                | <p>dfi_alert_err_int_en<br/>Interrupt enable bit for DFI alert error. If this bit is set, any parity/CRC error detected on the dfi_alert_n input will result in an interrupt being set on CRCPARSTAT.dfi_alert_err_int.</p> <p>Programming Mode: Dynamic</p>                                                       |

**DDRC\_CRCPARCTL1**

Address: Operational Base + offset (0x00c4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | <p>retry_add_rd_lat<br/>Retry additional read latency value. Delay value used is retry_add_rd_lat+1. Only used if CRCPARCTL1.retry_add_rd_lat_en is enabled.</p> <p>Selects the number of pipeline stages to dfi_rddata_valid/dfi_rddata/dfi_rddata_dbi before rest of internal uMCTL2 logic observes it.</p> <p>Required to compensate for fact delay in PHY/PCB for generating dfi_alert_n for retry may be more than the delay in PHY/PCB on read data path.</p> <p>Recommended settings (in terms of core_ddrc_core_clk):<br/>(Maximum Alert delay through PHY/PCB from erroneous read command including tPAR_UNKNOWN) - (Minimum Read data delay through PHY/PCB from erroneous read command) + (PHY's max granularity of dfi_rddata beats that may be corrupted before erroneous Read)</p> <p>Note: This calculation depends on various items such as RL, tPAR_ALERT_ON/tPAR_UNKNOWN/RCD/PHY/PCB behavior.<br/>Unit: DFI clock cycles.<br/>Programming Mode: Static</p> |
| 15         | RW          | 0x0                | <p>retry_add_rd_lat_en<br/>Retry additional read latency enable. Number of pipeline stages selected is defined as CRCPARCTL1.retry_add_lat+1. Only set if CRCPARCTL1.crc_parity_retry_enable = 1</p> <p>Programming Mode: Static</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 14:13      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 12         | RW          | 0x1                | <p>caparity_disable_before_sr<br/>If DDR4-SDRAM's CA parity is enabled by INIT6.mr5[2:0]!=0 and this register is set to 1, CA parity is automatically disabled before Self-Refresh entry and enabled after SelfRefresh exit by issuing MR5.</p> <p>1: CA parity is disabled before Self-Refresh entry<br/>0: CA parity is not disabled before Self-Refresh entry</p> <p>If Geardown is used by MSTR.geardown_mode=1, this register must be set to 1.</p> <p>If this register set to 0, DRAMTMG5.t_ckesr and DRAMTMG5.t_cksre must be increased by PL(Parity latency)</p> <p>Programming Mode: Static</p>                                                                                                                                                                                                                                                                                                                                                                      |
| 11:8       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7          | RW          | 0x0                | crc_inc_dm<br>CRC Calculation setting register<br>1: CRC includes DM signal<br>0: CRC not includes DM signal<br>Present only in designs configured to support DDR4.<br>Programming Mode: Static                                                                                                                                        |
| 6:5        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                               |
| 4          | RW          | 0x0                | crc_enable<br>CRC enable Register<br>1: Enable generation of CRC<br>0: Disable generation of CRC<br>The setting of this register should match the CRC mode register setting in the DRAM.<br>Programming Mode: Static                                                                                                                   |
| 3:1        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                               |
| 0          | RW          | 0x0                | parity_enable<br>C/A Parity enable register<br>1: Enable generation of C/A parity and detection of C/A parity error<br>0: Disable generation of C/A parity and disable detection of C/A parity error<br>If RCD's parity error detection or SDRAM's parity detection is enabled, this register should be 1.<br>Programming Mode: Static |

**DDRC\_CRCPARSTAT**

Address: Operational Base + offset (0x00cc)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:18      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 17         | RO          | 0x0                | dfi_alert_err_fatl_int<br>Fatal parity error interrupt.<br>One or more these situation below happens, this interrupt bit is set:<br>MPSMX caused parity error. (RCD's parity error detection only)<br>Parity error happens again during software intervention time<br>MRS was in retry_fifo_max_hold_timer_x4 window from alert_n=0 or STAT.operating_mode is Init.<br>It remains set until cleared by CRCPARCTL0.dfi_alert_err_fatl_clr.<br>If this interrupt is asserted, system reset is strongly recommended.<br>Programming Mode: Static |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16         | RO          | 0x0                | <p>dfi_alert_err_int<br/>DFI alert error interrupt.<br/>If a parity/CRC error is detected on dfi_alert_n, and the interrupt is enabled by CRCPARCTL0.dfi_alert_err_int_en, this interrupt bit will be set. It will remain set until cleared by CRCPARCTL0.dfi_alert_err_int_clr</p> <p>Programming Mode: Static</p>                         |
| 15:0       | RO          | 0x0000             | <p>dfi_alert_err_cnt<br/>DFI alert error count.<br/>If a parity/CRC error is detected on dfi_alert_n, this counter be incremented. This is independent of the setting of CRCPARCTL0.dfi_alert_err_int_en. It will saturate at 0xFFFF, and can be cleared by asserting CRCPARCTL0.dfi_alert_err_cnt_clr.</p> <p>Programming Mode: Static</p> |

**DDRC INIT0**

Address: Operational Base + offset (0x00d0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30      | RW          | 0x0                | <p>skip_dram_init<br/>If lower bit is enabled the SDRAM initialization routine is skipped. The upper bit decides what state the controller starts up in when reset is removed</p> <p>00: SDRAM Intialization routine is run after power-up<br/>01: SDRAM Intialization routine is skipped after powerup.<br/>Controller starts up in Normal Mode<br/>11: SDRAM Intialization routine is skipped after powerup.<br/>Controller starts up in Self-refresh Mode<br/>10: SDRAM Intialization routine is run after power-up.<br/>Programming Mode: Quasi-dynamic Group 2</p>                                      |
| 29:26      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 25:16      | RW          | 0x002              | <p>post_cke_x1024<br/>Cycles to wait after driving CKE high to start the SDRAM initialization sequence.<br/>Unit: 1024 DFI clock cycles.<br/>DDR2 typically requires a 400 ns delay, requiring this value to be programmed to 2 at all clock speeds.<br/>LPDDR2/LPDDR3 typically requires this to be programmed for a delay of 200 us.<br/>LPDDR4 typically requires this to be programmed for a delay of 2 us.<br/>When the controller is operating in 1:2 frequency ratio mode, program this to JEDEC spec value divided by 2, and round it up to the next integer value.<br/>Programming Mode: Static</p> |
| 15:12      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11:0       | RW          | 0x04e              | <p>pre_cke_x1024<br/>Cycles to wait after reset before driving CKE high to start the SDRAM initialization sequence.<br/>Unit: 1024 DFI clock cycles.</p> <p>DDR2 specifications typically require this to be programmed for a delay of <math>\geq 200</math> us.</p> <p>LPDDR2/LPDDR3: tINIT1 of 100 ns (min)<br/>LPDDR4: tINIT3 of 2 ms (min)</p> <p>When the controller is operating in 1:2 frequency ratio mode, program this to JEDEC spec value divided by 2, and round it up to the next integer value.</p> <p>Programming Mode: Static</p> |

**DDRC INIT1**

Address: Operational Base + offset (0x00d4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:25      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                        |
| 24:16      | RW          | 0x000              | <p>dram_rstn_x1024<br/>Number of cycles to assert SDRAM reset signal during init sequence.<br/>This is only present for designs supporting DDR3, DDR4 or LPDDR4 devices.</p> <p>When the controller is operating in 1:2 frequency ratio mode, program this to JEDEC spec value divided by 2, and round it up to the next integer value.</p> <p>Unit: 1024 DFI clock cycles.</p> <p>Programming Mode: Static</p> |
| 15:4       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                        |
| 3:0        | RW          | 0x0                | <p>pre_ocd_x32<br/>Wait period before driving the OCD complete command to SDRAM.<br/>Unit: Counts of a global timer that pulses every 32 DFI clock cycles.<br/>There is no known specific requirement for this; it may be set to zero.</p> <p>Programming Mode: Static</p>                                                                                                                                      |

**DDRC INIT2**

Address: Operational Base + offset (0x00d8)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:8       | RW          | 0x0d               | <p>idle_after_reset_x32<br/>Idle time after the reset command, tINIT4. Present only in designs configured to support LPDDR2.</p> <p>When the controller is operating in 1:2 frequency ratio mode, program this to JEDEC spec value divided by 2, and round it up to the next integer value.</p> <p>Unit: 32 DFI clock cycles.<br/>Programming Mode: Static</p>                                                               |
| 7:4        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 3:0        | RW          | 0x5                | <p>min_stable_clock_x1<br/>Time to wait after the first CKE high, tINIT2. Present only in designs configured to support LPDDR2/LPDDR3.</p> <p>LPDDR2/LPDDR3 typically requires 5 x tCK delay.</p> <p>When the controller is operating in 1:2 frequency ratio mode, program this to JEDEC spec value divided by 2, and round it up to the next integer value.</p> <p>Unit: DFI clock cycles.<br/>Programming Mode: Static</p> |

**DDRC INIT3**

Address: Operational Base + offset (0x00dc)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | <p>mr<br/>DDR2: Value to write to MR register. Bit 8 is for DLL and the setting here is ignored. The uMCTL2 sets this bit appropriately.<br/>DDR3/DDR4: Value loaded into MR0 register.<br/>mDDR: Value to write to MR register.<br/>LPDDR2/LPDDR3/LPDDR4 - Value to write to MR1 register<br/>Programming Mode: Quasi-dynamic Group 1 and Group 4</p>                                                                                                                                        |
| 15:0       | RW          | 0x0510             | <p>emr<br/>DDR2: Value to write to EMR register. Bits 9:7 are for OCD and the setting in this register is ignored. The uMCTL2 sets those bits appropriately.<br/>DDR3/DDR4: Value to write to MR1 register Set bit 7 to 0. If PHY-evaluation mode training is enabled, this bit is set appropriately by the uMCTL2 during write leveling.<br/>mDDR: Value to write to EMR register.<br/>LPDDR2/LPDDR3/LPDDR4 - Value to write to MR2 register<br/>Programming Mode: Quasi-dynamic Group 4</p> |

**DDRC INIT4**

Address: Operational Base + offset (0x00e0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | emr2<br>DDR2: Value to write to EMR2 register.<br>DDR3/DDR4: Value to write to MR2 register<br>LPDDR2/LPDDR3/LPDDR4: Value to write to MR3 register<br>mDDR: Unused<br>Programming Mode: Quasi-dynamic Group 4              |
| 15:0       | RW          | 0x0000             | emr3<br>DDR2: Value to write to EMR3 register.<br>DDR3/DDR4: Value to write to MR3 register<br>mDDR/LPDDR2/LPDDR3: Unused<br>LPDDR4: Value to write to MR13 register<br>Programming Mode: Quasi-dynamic Group 2 and Group 4 |

**DDRC INIT5**

Address: Operational Base + offset (0x00e4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 23:16      | RW          | 0x10               | dev_zqinit_x32<br>ZQ initial calibration, tZQINIT. Present only in designs configured to support DDR3 or DDR4 or LPDDR2/LPDDR3.<br>DDR3 typically requires 512 SDRAM clock cycles.<br>DDR4 requires 1024 SDRAM clock cycles.<br>LPDDR2/LPDDR3 requires 1 us.<br>When the controller is operating in 1:2 frequency ratio mode, program this to JEDEC spec value divided by 2, and round it up to the next integer value.<br>Unit: 32 DFI clock cycles.<br>Programming Mode: Static |
| 15:10      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 9:0        | RW          | 0x004              | max_auto_init_x1024<br>Maximum duration of the auto initialization, tINIT5. Present only in designs configured to support LPDDR2/LPDDR3.<br>LPDDR2/LPDDR3 typically requires 10 us.<br>Unit: 1024 DFI clock cycles.<br>Programming Mode: Static                                                                                                                                                                                                                                   |

**DDRC INIT6**

Address: Operational Base + offset (0x00e8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | mr4<br>DDR4- Value to be loaded into SDRAM MR4 registers.<br>LPDDR4- Value to be loaded into SDRAM MR11 registers.<br>Programming Mode: Quasi-dynamic Group 2 and Group 4 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0       | RW          | 0x0000             | mr5<br>DDR4- Value to be loaded into SDRAM MR5 registers.<br>LPDDR4- Value to be loaded into SDRAM MR12 registers.<br>Programming Mode: Quasi-dynamic Group 1 and Group 4 |

**DDRC INIT7**

Address: Operational Base + offset (0x00ec)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | mr6<br>DDR4- Value to be loaded into SDRAM MR6 registers.<br>LPDDR4- Value to be loaded into SDRAM MR14 registers.<br>Programming Mode: Quasi-dynamic Group 4 |
| 15:0       | RW          | 0x0000             | mr22<br>LPDDR4- Value to be loaded into SDRAM MR22 registers.<br>Used in LPDDR4 designs only.<br>Programming Mode: Quasi-dynamic Group 4                      |

**DDRC DIMMCTL**

Address: Operational Base + offset (0x00f0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 4          | RW          | 0x0                | mrs_bg1_en<br>Enable for BG1 bit of MRS command.<br>BG1 bit of the mode register address is specified as RFU<br>(Reserved for Future Use) and must be programmed to 0 during<br>MRS. In case where DRAMs which do not have BG1 are attached<br>and both the CA parity and the Output Inversion are enabled, this<br>must be set to 0, so that the calculation of CA parity will not<br>include BG1 bit.<br>Note: This has no effect on the address of any other memory<br>accesses, or of software-driven mode register accesses.<br>If address mirroring is enabled, this is applied to BG1 of even<br>ranks and BG0 of odd ranks.<br>1: Enabled; 0: Disabled<br>Programming Mode: Static |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3          | RW          | 0x0                | <p>mrs_a17_en<br/>Enable for A17 bit of MRS command.<br/>A17 bit of the mode register address is specified as RFU (Reserved for Future Use) and must be programmed to 0 during MRS. In case where DRAMs which do not have A17 are attached and the Output Inversion are enabled, this must be set to 0, so that the calculation of CA parity will not include A17 bit.<br/>Note: This has no effect on the address of any other memory accesses, or of software-driven mode register accesses.<br/>1: Enabled; 0: Disabled<br/>Programming Mode: Static</p> |
| 2:0        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

**DDRC\_RANKCTL**

Address: Operational Base + offset (0x00f4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:12      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 11:8       | RW          | 0x6                | <p>diff_rank_wr_gap<br/>Only present for multi-rank configurations.<br/>Indicates the number of clocks of gap in data responses when performing consecutive writes to different ranks.<br/>This is used to switch the delays in the PHY to match the rank requirements. This value should consider both PHY requirement and ODT requirement.<br/>PHY requirement:<br/>tphy_wrcsgap (see PHY databook for value of tphy_wrcsgap)<br/>If CRC feature is enabled, should be increased by 1.<br/>If write preamble is set to 2tCK(DDR4 only), should be increased by 1.<br/>If write postamble is set to 1.5tCK(LPDDR4 only), should be increased by 1.<br/>ODT requirement:<br/>The value programmed in this register takes care of the ODT switch off timing requirement when switching ranks during writes.<br/>For LPDDR4, the requirement is ODTLoff - ODTLon - BL/2 + 1<br/>When the controller is operating in 1:2 mode, program this to the larger value divided by two and round it up to the next integer.<br/>Programming Mode: Quasi-dynamic Group 2</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:4        | RW          | 0x6                | <p>diff_rank_rd_gap<br/>Only present for multi-rank configurations.<br/>Indicates the number of clocks of gap in data responses when performing consecutive reads to different ranks.<br/>This is used to switch the delays in the PHY to match the rank requirements.<br/>This value should consider both PHY requirement and ODT requirement.</p> <p>PHY requirement:<br/>tphy_rdcsgap (see PHY databook for value of tphy_rdcsgap)<br/>If read preamble is set to 2tCK(DDR4 only), should be increased by 1.<br/>If read postamble is set to 1.5tCK(LPDDR4 only), should be increased by 1.</p> <p>ODT requirement:<br/>The value programmed in this register takes care of the ODT switch off timing requirement when switching ranks during reads.<br/>When the controller is operating in 1:2 mode, program this to the larger value divided by two and round it up to the next integer.</p> <p>Programming Mode: Static</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 3:0        | RW          | 0xf                | <p>max_rank_rd<br/>Only present for multi-rank configurations.<br/>Background: Reads to the same rank can be performed back-to-back. Reads to different ranks require additional gap dictated by the register RANKCTL.diff_rank_rd_gap. This is to avoid possible data bus contention as well as to give PHY enough time to switch the delay when changing ranks. The uMCTL2 arbitrates for bus access on a cycle-by-cycle basis; therefore after a read is scheduled, there are few clock cycles (determined by the value on RANKCTL.diff_rank_rd_gap register) in which only reads from the same rank are eligible to be scheduled. This prevents reads from other ranks from having fair access to the data bus.<br/>This parameter represents the maximum number of reads that can be scheduled consecutively to the same rank. After this number is reached, a delay equal to RANKCTL.diff_rank_rd_gap is inserted by the scheduler to allow all ranks a fair opportunity to be scheduled. Higher numbers increase bandwidth utilization, lower numbers increase fairness.<br/>This feature can be DISABLED by setting this register to 0.<br/>When set to 0, the Controller will stay on the same rank as long as commands are available for it.<br/>Minimum programmable value is 0 (feature disabled) and maximum programmable value is 0xF.</p> <p>Programming Mode: Static</p> |

**DDRC\_DRAMTMG0**

Address: Operational Base + offset (0x0100)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 30:24      | RW          | 0x0f               | <p>wr2pre<br/>Minimum time between write and precharge to same bank.<br/>Unit: DFI Clocks<br/>Specifications: WL + BL/2 + tWR = approximately 8 cycles + 15 ns = 14 clocks @400MHz and less for lower frequencies where:<br/>WL = write latency<br/>BL = burst length. This must match the value programmed in the BL bit of the mode register to the SDRAM. BST (burst terminate) is not supported at present.<br/>tWR = Write recovery time. This comes directly from the SDRAM specification.<br/>Add one extra cycle for LPDDR2/LPDDR3/LPDDR4 for this parameter.</p> <p>When the controller is operating in 1:2 frequency ratio mode, 1T mode, divide the above value by 2. No rounding up.<br/>When the controller is operating in 1:2 frequency ratio mode, 2T mode or LPDDR4 mode, divide the above value by 2 and round it up to the next integer value.</p> <p>Programming Mode: Quasi-dynamic Group 1 and Group 2 and Group 4</p> |
| 23:22      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 21:16      | RW          | 0x10               | <p>t_faw<br/>tFAW Valid only when 8 or more banks(or banks x bank groups) are present.<br/>In 8-bank design, at most 4 banks must be activated in a rolling window of tFAW cycles.</p> <p>When the controller is operating in 1:2 frequency ratio mode, program this to (tFAW/2) and round up to next integer value.<br/>In a 4-bank design, set this register to 0x1 independent of the 1:1/1:2 frequency mode.<br/>Unit: DFI Clocks<br/>Programming Mode: Quasi-dynamic Group 2 and Group 4</p>                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 15         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 14:8       | RW          | 0x1b               | <p>t_ras_max<br/>tRAS(max): Maximum time between activate and precharge to same bank. This is the maximum time that a page can be kept open Minimum value of this register is 1. Zero is invalid.<br/>When the controller is operating in 1:2 frequency ratio mode, program this to (tRAS(max)-1)/2. No rounding up.<br/>Unit: Multiples of 1024 DFI clocks.<br/>Programming Mode: Quasi-dynamic Group 2 and Group 4</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 5:0        | RW          | 0x0f               | t_ras_min<br>tRAS(min): Minimum time between activate and precharge to the same bank.<br>When the controller is operating in 1:2 frequency mode, 1T mode, program this to tRAS(min)/2. No rounding up.<br>When the controller is operating in 1:2 frequency ratio mode, 2T mode or LPDDR4 mode, program this to (tRAS(min)/2) and round it up to the next integer value.<br>Unit: DFI Clocks<br>Programming Mode: Quasi-dynamic Group 2 and Group 4 |

**DDRC\_DRAMTMG1**

Address: Operational Base + offset (0x0104)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:21      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 20:16      | RW          | 0x08               | t_xp<br>tXP: Minimum time after power-down exit to any operation.<br>For DDR3, this should be programmed to tXPDLL if slow powerdown exit is selected in MR0[12].<br>If C/A parity for DDR4 is used, set to (tXP+PL) instead.<br>If LPDDR4 is selected and its spec has tCKELPD parameter, set to the larger of tXP and tCKELPD instead.<br>When the controller is operating in 1:2 frequency ratio mode, program this to (tXP/2) and round it up to the next integer value.<br>Units: DFI Clocks<br>Programming Mode: Quasi-dynamic Group 2 and Group 4 |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:8       | RW          | 0x04               | <p>rd2pre<br/> tRTP: Minimum time from read to precharge of same bank.<br/> DDR2: tAL + BL/2 + max(tRTP, 2) - 2<br/> DDR3: tAL + max (tRTP, 4)<br/> DDR4: Max of following two equations: tAL + max (tRTP, 4) or,<br/> RL + BL/2 - tRP (*).<br/> mDDR: BL/2<br/> LPDDR2: Depends on if it's LPDDR2-S2 or LPDDR2-S4:<br/> LPDDR2-S2: BL/2 + tRTP - 1. LPDDR2-S4: BL/2 + max(tRTP,2) - 2.<br/> LPDDR3: BL/2 + max(tRTP,4) - 4<br/> LPDDR4: BL/2 + max(tRTP,8) - 8<br/> (*) When both DDR4 SDRAM and ST-MRAM are used simultaneously, use SDRAM's tRP value for calculation.<br/> When the controller is operating in 1:2 mode, 1T mode, divide the above value by 2. No rounding up.<br/> When the controller is operating in 1:2 mode, 2T mode or LPDDR4 mode, divide the above value by 2 and round it up to the next integer value.<br/> Unit: DFI Clocks.<br/> Programming Mode: Quasi-dynamic Group 1 and Group 2 and Group 4</p> |
| 7          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 6:0        | RW          | 0x14               | <p>t_rc<br/> tRC: Minimum time between activates to same bank.<br/> When the controller is operating in 1:2 frequency ratio mode, program this to (tRC/2) and round up to next integer value.<br/> Unit: DFI Clocks.<br/> Programming Mode: Quasi-dynamic Group 2 and Group 4</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

**DDRC\_DRAMTMG2**

Address: Operational Base + offset (0x0108)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 29:24      | RW          | 0x03               | <p>write_latency</p> <p>Set to WL. Time from write command to write data on SDRAM interface.</p> <p>For mDDR, it should normally be set to 1.</p> <p>When the controller is operating in 1:2 frequency ratio mode, divide the value calculated using the above equation by 2, and round it up to next integer.</p> <p>This register field is not required for DDR2 and DDR3 (except if MEMC_TRAINING is set), as the DFI read and write latencies defined in DFITMG0 and DFITMG1 are sufficient for those protocols</p> <p>Unit: DFI clocks</p> <p>Programming Mode: Quasi-dynamic Group 1 and Group 2 and Group 4</p> |
| 23:22      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 21:16      | RW          | 0x05               | <p>read_latency</p> <p>Set to RL. Time from read command to read data on SDRAM interface.</p> <p>When the controller is operating in 1:2 frequency ratio mode, divide the value calculated using the above equation by 2, and round it up to next integer.</p> <p>This register field is not required for DDR2 and DDR3 (except if MEMC_TRAINING is set), as the DFI read and write latencies defined in DFITMG0 and DFITMG1 are sufficient for those protocols</p> <p>Unit: DFI clocks</p> <p>Programming Mode: Quasi-dynamic Group 1 and Group 2 and Group 4</p>                                                     |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:8       | RW          | 0x06               | <p>rd2wr<br/>         DDR2/3/mDDR: RL + BL/2 + 2 - WL<br/>         DDR4: RL + BL/2 + 1 + WR_PREAMBLE - WL<br/>         LPDDR2/LPDDR3: RL + BL/2 + RU(tDQSKmax/tCK) + 1 - WL<br/>         LPDDR4(DQ ODT is Disabled): RL + BL/2 + RU(tDQSKmax/tCK) + WR_PREAMBLE + RD_POSTAMBLE - WL<br/>         LPDDR4(DQ ODT is Enabled) : RL + BL/2 + RU(tDQSKmax/tCK) + RD_POSTAMBLE - ODTlon - RU(tODTon(min)/tCK)<br/>         Minimum time from read command to write command.<br/>         Include time for bus turnaround and all per-bank, per-rank, and global constraints. Please see the relevant PHY databook for details of what should be included here.<br/>         Unit: DFI Clocks.<br/>         Where:<br/>         WL = write latency<br/>         BL = burst length. This must match the value programmed in the BL bit of the mode register to the SDRAM<br/>         RL = read latency = CAS latency<br/>         WR_PREAMBLE = write preamble. This is unique to DDR4 and LPDDR4.<br/>         RD_POSTAMBLE = read postamble. This is unique to LPDDR4.<br/>         For LPDDR2/LPDDR3/LPDDR4, if derating is enabled (DERATEEN.derate_enable=1), derated tDQSKmax should be used.<br/>         When the controller is operating in 1:2 frequency ratio mode, divide the value calculated using the above equation by 2, and round it up to next integer.<br/>         Programming Mode: Quasi-dynamic Group 1 and Group 2 and Group 4</p> |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5:0        | RW          | 0x0d               | <p>wr2rd<br/>         DDR4: CWL + PL + BL/2 + tWTR_L<br/>         LPDDR2/3/4: WL + BL/2 + tWTR + 1<br/>         Others: CWL + BL/2 + tWTR</p> <p>In DDR4, minimum time from write command to read command for same bank group. In others, minimum time from write command to read command. Includes time for bus turnaround, recovery times, and all per-bank, per-rank, and global constraints.</p> <p>Unit: DFI Clocks.</p> <p>Where:</p> <p>CWL = CAS write latency</p> <p>WL = Write latency</p> <p>PL = Parity latency</p> <p>BL = burst length. This must match the value programmed in the BL bit of the mode register to the SDRAM</p> <p>tWTR_L = internal write to read command delay for same bank group. This comes directly from the SDRAM specification.</p> <p>tWTR = internal write to read command delay. This comes directly from the SDRAM specification.</p> <p>Add one extra cycle for LPDDR2/LPDDR3/LPDDR4 operation.</p> <p>When the controller is operating in 1:2 mode, divide the value calculated using the above equation by 2, and round it up to next integer.</p> <p>Programming Mode: Quasi-dynamic Group 1 and Group 2 and Group 4</p> |

**DDRC\_DRAMTMG3**

Address: Operational Base + offset (0x010c)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 29:20      | RW          | 0x005              | <p>t_mrw<br/>Time to wait after a mode register write or read (MRW or MRR). Present only in designs configured to support LPDDR2, LPDDR3 or LPDDR4.</p> <p>LPDDR2 typically requires value of 5.<br/>LPDDR3 typically requires value of 10.</p> <p>LPDDR4: Set this to the larger of tMRW and tMRWCKEL.</p> <p>For LPDDR2, this register is used for the time from a MRW/MRR to all other commands.</p> <p>When the controller is operating in 1:2 frequency ratio mode, program this to the above values divided by 2 and round it up to the next integer value.</p> <p>For LPDDR3, this register is used for the time from a MRW/MRR to a MRW/MRR.</p> <p>Programming Mode: Quasi-dynamic Group 2 and Group 4</p> |
| 19:18      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 17:12      | RW          | 0x04               | <p>t_mrd<br/>tMRD: Cycles to wait after a mode register write or read.</p> <p>Depending on the connected SDRAM, tMRD represents:</p> <p>DDR2/mDDR: Time from MRS to any command<br/>DDR3/4: Time from MRS to MRS command<br/>LPDDR2: not used<br/>LPDDR3/4: Time from MRS to non-MRS command.</p> <p>When the controller is operating in 1:2 frequency ratio mode, program this to (tMRD/2) and round it up to the next integer value.</p> <p>If C/A parity for DDR4 is used, set to tMRD_PAR(tMOD+PL) instead.</p> <p>Programming Mode: Quasi-dynamic Group 2 and Group 4</p>                                                                                                                                      |
| 11:10      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 9:0        | RW          | 0x00c              | <p>t_mod<br/>tMOD: Parameter used only in DDR3 and DDR4. Cycles between load mode command and following non-load mode command.</p> <p>If C/A parity for DDR4 is used, set to tMOD_PAR(tMOD+PL) instead.</p> <p>If MPR writes for DDR4 are used, set to tMOD + AL (or tMPD_PAR + AL if C/A parity is also used).</p> <p>Set to tMOD/2 (rounded up to next integer) if controller is operating in 1:2 frequency ratio mode.</p> <p>Programming Mode: Quasi-dynamic Group 2 and Group 4</p>                                                                                                                                                                                                                            |

**DDRC\_DRAMTMG4**

Address: Operational Base + offset (0x0110)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 28:24      | RW          | 0x05               | <p>t_rcd</p> <p>tRCD - tAL: Minimum time from activate to read or write command to same bank.</p> <p>When the controller is operating in 1:2 frequency ratio mode, program this to ((tRCD - tAL)/2) and round it up to the next integer value.</p> <p>Minimum value allowed for this register is 1, which implies minimum (tRCD - tAL) value to be 2 when the controller is operating in 1:2 frequency ratio mode.</p> <p>Unit: DFI Clocks.</p> <p>Programming Mode: Quasi-dynamic Group 1 and Group 2 and Group 4</p> |
| 23:20      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 19:16      | RW          | 0x4                | <p>t_ccd</p> <p>DDR4: tCCD_L: This is the minimum time between two reads or two writes for same bank group.</p> <p>Others: tCCD: This is the minimum time between two reads or two writes.</p> <p>When the controller is operating in 1:2 frequency ratio mode, program this to (tCCD_L/2 or tCCD/2) and round it up to the next integer value.</p> <p>Unit: DFI clocks.</p> <p>Programming Mode: Quasi-dynamic Group 2 and Group 4</p>                                                                                |
| 15:12      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 11:8       | RW          | 0x4                | <p>t_rrd</p> <p>DDR4: tRRD_L: Minimum time between activates from bank "a" to bank "b" for same bank group.</p> <p>Others: tRRD: Minimum time between activates from bank "a" to bank "b"</p> <p>When the controller is operating in 1:2 frequency ratio mode, program this to (tRRD_L/2 or tRRD/2) and round it up to the next integer value.</p> <p>Unit: DFI Clocks.</p> <p>Programming Mode: Quasi-dynamic Group 2 and Group 4</p>                                                                                 |
| 7:5        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 4:0        | RW          | 0x05               | <p>t_rp</p> <p>tRP: Minimum time from precharge to activate of same bank.</p> <p>When the controller is operating in 1:2 frequency ratio mode, t_rp should be set to RoundDown(RoundUp(tRP/tCK)/2) + 1.</p> <p>When the controller is operating in 1:2 frequency ratio mode in LPDDR4, t_rp should be set to RoundUp(RoundUp(tRP/tCK)/2).</p> <p>Unit: DFI Clocks.</p> <p>Programming Mode: Quasi-dynamic Group 2 and Group 4</p>                                                                                      |

**DDRC DRAMTMG5**

Address: Operational Base + offset (0x0114)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 27:24      | RW          | 0x5                | <p>t_cksr<sub>x</sub><br/> This is the time before Self Refresh Exit that CK is maintained as a valid clock before issuing SRX. Specifies the clock stable time before SRX.</p> <p>Recommended settings:<br/> mDDR: 1<br/> LPDDR2: 2<br/> LPDDR3: 2<br/> LPDDR4: tCKC<sub>E</sub>H<br/> DDR2: 1<br/> DDR3: tCKSR<sub>X</sub><br/> DDR4: tCKSR<sub>X</sub></p> <p>When the controller is operating in 1:2 frequency ratio mode, program this to recommended value divided by two and round it up to next integer.</p> <p>Programming Mode: Quasi-dynamic Group 2 and Group 4</p>                                                                                                                                |
| 23:20      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 19:16      | RW          | 0x5                | <p>t_cks<sub>r</sub>e<br/> This is the time after Self Refresh Down Entry that CK is maintained as a valid clock. Specifies the clock disable delay after SRE.</p> <p>Recommended settings:<br/> mDDR: 0<br/> LPDDR2: 2<br/> LPDDR3: 2<br/> LPDDR4: tCKE<sub>L</sub>C<sub>K</sub><br/> DDR2: 1<br/> DDR3: max (10 ns, 5 tCK)<br/> DDR4: max (10 ns, 5 tCK) (+ PL(parity latency)(*))</p> <p>(*)Only if CRCPARCTL1.caparity_disable_before_sr=0, this register should be increased by PL.</p> <p>When the controller is operating in 1:2 frequency ratio mode, program this to recommended value divided by two and round it up to next integer.</p> <p>Programming Mode: Quasi-dynamic Group 2 and Group 4</p> |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:8       | RW          | 0x04               | <p>t_ckesr<br/>Minimum CKE low width for Self refresh or Self refresh power down entry to exit timing in memory clock cycles.<br/>Recommended settings:<br/>mDDR: tRFC<br/>LPDDR2: tCKESR<br/>LPDDR3: tCKESR<br/>LPDDR4: max(tCKE, tSR)<br/>DDR2: tCKE<br/>DDR3: tCKE + 1<br/>DDR4: tCKE + 1 (+ PL(parity latency))(*)<br/>(*)Only if CRCPARCTL1.capacity_disable_before_sr=0, this register should be increased by PL.<br/>When the controller is operating in 1:2 frequency ratio mode, program this to recommended value divided by two and round it up to next integer.<br/>Programming Mode: Quasi-dynamic Group 2 and Group 4</p> |
| 7:5        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 4:0        | RW          | 0x03               | <p>t_cke<br/>Minimum number of cycles of CKE HIGH/LOW during power-down and self refresh.<br/>LPDDR2/LPDDR3 mode: Set this to the larger of tCKE or tCKESR<br/>LPDDR4 mode: Set this to the larger of tCKE or tSR.<br/>Non-LPDDR2/non-LPDDR3/non-LPDDR4 designs: Set this to tCKE value.<br/>When the controller is operating in 1:2 frequency ratio mode, program this to (value described above)/2 and round it up to the next integer value.<br/>Unit: DFI Clocks.<br/>Programming Mode: Quasi-dynamic Group 2 and Group 4</p>                                                                                                       |

**DDRC\_DRAMTMG6**

Address: Operational Base + offset (0x0118)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 27:24      | RW          | 0x2                | <p>t_ckdpde</p> <p>This is the time before Self Refresh Exit that CK is maintained as a valid clock before issuing SRX. Specifies the clock stable time before SRX.</p> <p>Recommended settings:</p> <ul style="list-style-type: none"> <li>mDDR: 1</li> <li>LPDDR2: 2</li> <li>LPDDR3: 2</li> <li>LPDDR4: tCKCKEH</li> <li>DDR2: 1</li> <li>DDR3: tCKSRX</li> <li>DDR4: tCKSRX</li> </ul> <p>When the controller is operating in 1:2 frequency ratio mode, program this to recommended value divided by two and round it up to next integer.</p> <p>Programming Mode: Quasi-dynamic Group 2 and Group 4</p> |
| 23:20      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 19:16      | RW          | 0x2                | <p>t_ckdpdx</p> <p>This is the time before Deep Power Down Exit that CK is maintained as a valid clock before issuing DPDX. Specifies the clock stable time before DPDX.</p> <p>Recommended settings:</p> <ul style="list-style-type: none"> <li>mDDR: 1</li> <li>LPDDR2: 2</li> <li>LPDDR3: 2</li> </ul> <p>When the controller is operating in 1:2 frequency ratio mode, program this to recommended value divided by two and round it up to next integer.</p> <p>This is only present for designs supporting mDDR or LPDDR2 devices.</p> <p>Programming Mode: Quasi-dynamic Group 2 and Group 4</p>       |
| 15:4       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0        | RW          | 0x5                | <p>t_ckcsx<br/>This is the time before Clock Stop Exit that CK is maintained as a valid clock before issuing Clock Stop Exit. Specifies the clock stable time before next command after Clock Stop Exit.<br/>Recommended settings:<br/>mDDR: 1<br/>LPDDR2: tXP + 2<br/>LPDDR3: tXP + 2<br/>LPDDR4: tXP + 2<br/>When the controller is operating in 1:2 frequency ratio mode, program this to recommended value divided by two and round it up to next integer.<br/>This is only present for designs supporting mDDR or LPDDR2/LPDDR3/LPDDR4 devices.<br/>Programming Mode: Quasi-dynamic Group 2 and Group 4</p> |

**DDRC\_DRAMTMG7**

Address: Operational Base + offset (0x011c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:12      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 11:8       | RW          | 0x2                | <p>t_ckptde<br/>This is the time after Power Down Entry that CK is maintained as a valid clock. Specifies the clock disable delay after PDE.<br/>Recommended settings:<br/>mDDR: 0<br/>LPDDR2: 2<br/>LPDDR3: 2<br/>LPDDR4: tCKELCK<br/>When using DDR2/3/4 SDRAM, this register should be set to the same value as DRAMTMG5.t_cksre. When the controller is operating in 1:2 frequency ratio mode, program this to recommended value divided by two and round it up to next integer.<br/>This is only present for designs supporting mDDR or LPDDR2/LPDDR3/LPDDR4 devices.<br/>Programming Mode: Quasi-dynamic Group 2 and Group 4</p> |
| 7:4        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0        | RW          | 0x2                | <p>t_ckpdx<br/>This is the time before Power Down Exit that CK is maintained as a valid clock before issuing PDX. Specifies the clock stable time before PDX.</p> <p>Recommended settings:<br/>mDDR: 0<br/>LPDDR2: 2<br/>LPDDR3: 2<br/>LPDDR4: 2</p> <p>When using DDR2/3/4 SDRAM, this register should be set to the same value as DRAMTMG5.t_cksr. When the controller is operating in 1:2 frequency ratio mode, program this to recommended value divided by two and round it up to next integer.</p> <p>This is only present for designs supporting mDDR or LPDDR2/LPDDR3/LPDDR4 devices.</p> <p>Programming Mode: Quasi-dynamic Group 2 and Group 4</p> |

**DDRC\_DRAMTMG8**

Address: Operational Base + offset (0x0120)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 30:24      | RW          | 0x03               | <p>t_xs_fast_x32<br/>tXS_FAST: Exit Self Refresh to ZQCL, ZQCS and MRS (only CL, WR, RTP and Geardown mode).</p> <p>When the controller is operating in 1:2 frequency ratio mode, program this to the above value divided by 2 and round up to next integer value.</p> <p>Unit: Multiples of 32 DFI clocks.</p> <p>Note: This is applicable to only ZQCL/ZQCS commands.</p> <p>Note: Ensure this is less than or equal to t_xs_x32.</p> <p>Programming Mode: Quasi-dynamic Group 2 and Group 4</p> |
| 23         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 22:16      | RW          | 0x03               | <p>t_xs_abort_x32<br/>tXS_ABORT: Exit Self Refresh to commands not requiring a locked DLL in Self Refresh Abort.</p> <p>When the controller is operating in 1:2 frequency ratio mode, program this to the above value divided by 2 and round up to next integer value.</p> <p>Unit: Multiples of 32 DFI clocks.</p> <p>Note: Ensure this is less than or equal to t_xs_x32.</p> <p>Programming Mode: Quasi-dynamic Group 2 and Group 4</p>                                                         |
| 15         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14:8       | RW          | 0x44               | t_xs_dll_x32<br>tXSDLL: Exit Self Refresh to commands requiring a locked DLL.<br>When the controller is operating in 1:2 frequency ratio mode, program this to the above value divided by 2 and round up to next integer value.<br>Unit: Multiples of 32 DFI clocks.<br>Note: Used only for DDR2, DDR3 and DDR4 SDRAMs.<br>Programming Mode: Quasi-dynamic Group 2 and Group 4 |
| 7          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                       |
| 6:0        | RW          | 0x05               | t_xs_x32<br>tXS: Exit Self Refresh to commands not requiring a locked DLL.<br>When the controller is operating in 1:2 frequency ratio mode, program this to the above value divided by 2 and round up to next integer value.<br>Unit: Multiples of 32 DFI clocks.<br>Note: Used only for DDR2, DDR3 and DDR4 SDRAMs.<br>Programming Mode: Quasi-dynamic Group 2 and Group 4    |

**DDRC\_DRAMTMG9**

Address: Operational Base + offset (0x0124)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 30         | RW          | 0x0                | ddr4_wr_preamble<br>DDR4 Write preamble mode<br>0: 1tCK preamble<br>1: 2tCK preamble<br>Programming Mode: Quasi-dynamic Group 2 and Group 4                                                                                                                                                                                                                                                                                                                         |
| 29:19      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 18:16      | RW          | 0x4                | t_ccd_s<br>tCCD_S: This is the minimum time between two reads or two writes for different bank group. For bank switching (from bank "a" to bank "b"), the minimum time is this value + 1.<br>When the controller is operating in 1:2 frequency ratio mode, program this to (tCCD_S/2) and round it up to the next integer value.<br>Present only in designs configured to support DDR4.<br>Unit: DFI clocks.<br>Programming Mode: Quasi-dynamic Group 2 and Group 4 |
| 15:12      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11:8       | RW          | 0x4                | <p>t_rrd_s<br/>tRRD_S: Minimum time between activates from bank "a" to bank "b" for different bank group.</p> <p>When the controller is operating in 1:2 frequency ratio mode, program this to (tRRD_S/2) and round it up to the next integer value.</p> <p>Present only in designs configured to support DDR4.</p> <p>Unit: DFI Clocks.</p> <p>Programming Mode: Quasi-dynamic Group 2 and Group 4</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 5:0        | RW          | 0x0d               | <p>wr2rd_s<br/>CWL + PL + BL/2 + tWTR_S</p> <p>Minimum time from write command to read command for different bank group. Includes time for bus turnaround, recovery times, and all per-bank, per-rank, and global constraints.</p> <p>Present only in designs configured to support DDR4.</p> <p>Unit: DFI Clocks.</p> <p>Where:</p> <p>CWL = CAS write latency</p> <p>PL = Parity latency</p> <p>BL = burst length. This must match the value programmed in the BL bit of the mode register to the SDRAM</p> <p>tWTR_S = internal write to read command delay for different bank group. This comes directly from the SDRAM specification.</p> <p>When the controller is operating in 1:2 mode, divide the value calculated using the above equation by 2, and round it up to next integer.</p> <p>Programming Mode: Quasi-dynamic Group 1 and Group 2 and Group 4</p> |

**DDRC\_DRAMTMG10**

Address: Operational Base + offset (0x0128)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 20:16      | RW          | 0x1c               | <p>t_sync_gear<br/>Indicates the time between MRS command and the sync pulse time.<br/>This must be even number of clocks.<br/>For DDR4-2666 and DDR4-3200, this parameter is defined as tMOD(min)+4nCK<br/>tMOD(min) is greater of 24nCK or 15ns<br/>15ns / .625ns = 24<br/>Max value for this register is 24+4 = 28<br/>When the controller is operating in 1:2 mode, program this to (tSYNC_GEAR/2) and round it up to the next integer value.<br/>Unit: DFI Clocks<br/>Programming Mode: Quasi-dynamic Group 2 and Group 4</p> |
| 15:13      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 12:8       | RW          | 0x18               | <p>t_cmd_gear<br/>Sync pulse to first valid command.<br/>For DDR4-2666 and DDR4-3200, this parameter is defined as tMOD(min).<br/>tMOD(min) is greater of 24nCK or 15ns<br/>15ns / .625ns = 24<br/>Max value for this register is 24<br/>When the controller is operating in 1:2 mode, program this to (tCMD_GEAR/2) and round it up to the next integer value.<br/>Unit: DFI Clocks<br/>Programming Mode: Quasi-dynamic Group 2 and Group 4</p>                                                                                   |
| 7:4        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 3:2        | RW          | 0x2                | <p>t_gear_setup<br/>Geardown setup time.<br/>Minimum value of this register is 1. Zero is invalid. For DDR4-2666 and DDR4-3200, this parameter is defined as 2 clks<br/>When the controller is operating in 1:2 frequency ratio mode, program this to (tGEAR_setup/2) and round it up to the next integer value.<br/>Unit: DFI Clocks<br/>Programming Mode: Quasi-dynamic Group 2 and Group 4</p>                                                                                                                                  |
| 1:0        | RW          | 0x2                | <p>t_gear_hold<br/>Geardown hold time.<br/>Minimum value of this register is 1. Zero is invalid. For DDR4-2666 and DDR4-3200, this parameter is defined as 2 clks<br/>When the controller is operating in 1:2 frequency ratio mode, program this to (tGEAR_hold/2) and round it up to the next integer value.<br/>Unit: DFI Clocks<br/>Value After Reset: 0x2<br/>Programming Mode: Quasi-dynamic Group 2 and Group 4</p>                                                                                                          |

**DDRC DRAMTMG11**

Address: Operational Base + offset (0x012c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                               |
| 30:24      | RW          | 0x44               | <p>post_mpsm_gap_x32<br/>tXMPDLL: This is the minimum Exit MPSM to commands requiring a locked DLL.<br/>When the controller is operating in 1:2 frequency ratio mode, program this to (tXMPDLL/2) and round it up to the next integer value.<br/>Present only in designs configured to support DDR4.<br/>Unit: Multiples of 32 DFI clocks.<br/>Programming Mode: Quasi-dynamic Group 2 and Group 4</p> |
| 23:21      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                               |
| 20:16      | RW          | 0x0c               | <p>t_mpx_lh<br/>tMPX_LH: This is the minimum CS_n Low hold time to CKE rising edge.<br/>When the controller is operating in 1:2 frequency ratio mode, program this to RoundUp(tMPX_LH/2)+1.<br/>Present only in designs configured to support DDR4.<br/>Unit: DFI clocks.<br/>Programming Mode: Quasi-dynamic Group 2 and Group 4</p>                                                                  |
| 15:10      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                               |
| 9:8        | RW          | 0x2                | <p>t_mpx_s<br/>tMPX_S: Minimum time CS setup time to CKE.<br/>When the controller is operating in 1:2 frequency ratio mode, program this to (tMPX_S/2) and round it up to the next integer value.<br/>Present only in designs configured to support DDR4.<br/>Unit: DFI Clocks.<br/>Programming Mode: Quasi-dynamic Group 2 and Group 4</p>                                                            |
| 7:5        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                               |
| 4:0        | RW          | 0x1c               | <p>t_ckmpe<br/>tCKMPE: Minimum valid clock requirement after MPSM entry.<br/>Present only in designs configured to support DDR4.<br/>Unit: DFI Clocks.<br/>When the controller is operating in 1:2 frequency ratio mode, divide the value calculated using the above equation by 2, and round it up to next integer.<br/>Programming Mode: Quasi-dynamic Group 2 and Group 4</p>                       |

**DDRC DRAMTMG12**

Address: Operational Base + offset (0x0130)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:18      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                   |
| 17:16      | RW          | 0x2                | t_cmdcke<br>tCMDCKE: Delay from valid command to CKE input LOW.<br>Set this to the larger of tESCKE or tCMDCKE<br>When the controller is operating in 1:2 frequency ratio mode, program this to (max(tESCKE, tCMDCKE)/2) and round it up to the next integer value.<br>Programming Mode: Quasi-dynamic Group 2 and Group 4 |
| 15:5       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                   |
| 4:0        | RW          | 0x10               | t_mrd_pda<br>tMRD_PDA: This is the Mode Register Set command cycle time in PDA mode.<br>When the controller is operating in 1:2 frequency ratio mode, program this to (tMRD_PDA/2) and round it up to the next integer value.<br>Programming Mode: Quasi-dynamic Group 2 and Group 4                                       |

**DDRC\_DRAMTMG13**

Address: Operational Base + offset (0x0134)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                  |
| 30:24      | RW          | 0x1c               | odtloff<br>LPDDR4: tODTLooff: This is the latency from CAS-2 command to tODTOff reference.<br>When the controller is operating in 1:2 frequency ratio mode, program this to (tODTLooff/2) and round it up to the next integer value.<br>Unit: DFI Clocks.<br>Programming Mode: Quasi-dynamic Group 2 and Group 4                          |
| 23:22      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                  |
| 21:16      | RW          | 0x20               | t_ccd_mw<br>LPDDR4: tCCDMW: This is the minimum time from write or masked write to masked write command for same bank.<br>When the controller is operating in 1:2 frequency ratio mode, program this to (tCCDMW/2) and round it up to the next integer value.<br>Unit: DFI Clocks.<br>Programming Mode: Quasi-dynamic Group 2 and Group 4 |
| 15:3       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                    |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:0        | RW          | 0x4                | t_ppd<br>LPDDR4: tPPD: This is the minimum time from precharge to precharge command.<br>When the controller is operating in 1:2 frequency ratio mode, program this to (tPPD/2) and round it up to the next integer value.<br>Unit: DFI Clocks.<br>Programming Mode: Quasi-dynamic Group 2 and Group 4 |

**DDRC\_DRAMTMG14**

Address: Operational Base + offset (0x0138)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:12      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                         |
| 11:0       | RW          | 0x0a0              | t_xsr<br>tXSR: Exit Self Refresh to any command.<br>When the controller is operating in 1:2 frequency ratio mode, program this to the above value divided by 2 and round up to next integer value.<br>Note: Used only for mDDR/LPDDR2/LPDDR3/LPDDR4 mode.<br>Programming Mode: Quasi-dynamic Group 2 and Group 4 |

**DDRC\_DRAMTMG15**

Address: Operational Base + offset (0x013c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RW          | 0x0                | en_dfi_lp_t_stab<br>1: Enable using tSTAB when exiting DFI LP. Needs to be set when the PHY is stopping the clock during DFI LP to save maximum power.<br>0: Disable using tSTAB when exiting DFI LP<br>Programming Mode: Quasi-dynamic Group 2 and Group 4                                                                                                                                                                                                                                                                                                                                                                                                   |
| 30:8       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 7:0        | RW          | 0x00               | t_stab_x32<br>tSTAB: Stabilization time.<br>It is required in the following two cases for DDR3/DDR4 RDIMM : when exiting power saving mode, if the clock was stopped, after re-enabling it the clock must be stable for a time specified by tSTAB in the case of input clock frequency change (DDR4) after issuing control words that refers to clock timing (Specification: 6us for DDR3, 5us for DDR4)<br>When the controller is operating in 1:2 frequency ratio mode, program this to recommended value divided by two and round it up to next integer.<br>Unit: Multiples of 32 DFI clock cycles.<br>Programming Mode: Quasi-dynamic Group 2 and Group 4 |

**DDRC\_DRAMTMG17**

Address: Operational Base + offset (0x0144)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                      |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                         |
| 23:16 | RW   | 0x00        | t_vrcg_enable<br>LPDDR4: tVRCG_ENABLE: VREF high current mode enable time.<br>When the controller is operating in 1:2 frequency ratio mode,<br>program this to (tVRCG_ENABLE/2) and round it up to the next<br>integer value.<br>Unit: DFI clocks<br>Programming Mode: Quasi-dynamic Group 4     |
| 15:7  | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                         |
| 6:0   | RW   | 0x00        | t_vrcg_disable<br>LPDDR4: tVRCG_DISABLE: VREF high current mode disable time.<br>When the controller is operating in 1:2 frequency ratio mode,<br>program this to (tVRCG_DISABLE/2) and round it up to the next<br>integer value.<br>Unit: DFI clocks<br>Programming Mode: Quasi-dynamic Group 4 |

**DDRC\_ZQCTL0**

Address: Operational Base + offset (0x0180)

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31  | RW   | 0x0         | dis_auto_zq<br>1: Disable uMCTL2 generation of ZQCS/MPC(ZQ calibration)<br>command. Register<br>DBGCMD.zq_calib_short can be used instead to issue ZQ<br>calibration request from APB module.<br>0: Internally generate ZQCS/MPC(ZQ calibration) commands<br>based on ZQCTL1.t_zq_short_interval_x1024.<br>This is only present for designs supporting DDR3/DDR4 or<br>LPDDR2/LPDDR3/LPDDR4 devices.<br>Programming Mode: Dynamic                                                                                                    |
| 30  | RW   | 0x0         | dis_srx_zql<br>1: Disable issuing of ZQCL/MPC(ZQ calibration)<br>command at Self-Refresh/SR-Powerdown exit. Only applicable<br>when run in DDR3 or DDR4 or LPDDR2 or LPDDR3 or LPDDR4<br>mode.<br>0: Enable issuing of ZQCL/MPC(ZQ calibration)<br>command at Self-Refresh/SR-Powerdown exit. Only applicable<br>when run in DDR3 or DDR4 or LPDDR2 or LPDDR3 or LPDDR4<br>mode.<br>This is only present for designs supporting DDR3/DDR4 or<br>LPDDR2/LPDDR3/LPDDR4 devices.<br>Programming Mode: Quasi-dynamic Group 2 and Group 4 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 29         | RW          | 0x0                | <p>zq_resistor_shared<br/>           1: Denotes that ZQ resistor is shared between ranks.<br/>           Means ZQinit/ZQCL/ZQCS/MPC(ZQ calibration) commands are sent to one rank at a time with tZQinit/tZQCL/tZQCS/tZQCAL/tZQLAT timing met between commands so that commands to different ranks do not overlap.<br/>           0: ZQ resistor is not shared.<br/>           This is only present for designs supporting DDR3/DDR4 or LPDDR2/LPDDR3/LPDDR4 devices.<br/>           Programming Mode: Static</p>                                                                                                                                                                                                                                    |
| 28         | RW          | 0x0                | <p>dis_mpsmx_zqcl<br/>           1: Disable issuing of ZQCL command at Maximum Power Saving Mode exit. Only applicable when run in DDR4 mode.<br/>           0: Enable issuing of ZQCL command at Maximum Power Saving Mode exit. Only applicable when run in DDR4 mode.<br/>           This is only present for designs supporting DDR4 devices.<br/>           Note: Do not issue ZQCL command at Maximum Power Save Mode exit if the UMCTL2_SHARED_AC configuration parameter is set. Program it to 1'b1. The software can send ZQCS after exiting MPSM mode.<br/>           Programming Mode: Static</p>                                                                                                                                         |
| 27         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 26:16      | RW          | 0x200              | <p>t_zq_long_nop<br/>           tZQoper for DDR3/DDR4, tZQCL for LPDDR2/LPDDR3, tZQCAL for LPDDR4: Number of DFI clock cycles of NOP required after a ZQCL (ZQ calibration long)/MPC(ZQ Start) command is issued to SDRAM.<br/>           When the controller is operating in 1:2 frequency ratio mode:<br/>           DDR3/DDR4: program this to tZQoper/2 and round it up to the next integer value.<br/>           LPDDR2/LPDDR3: program this to tZQCL/2 and round it up to the next integer value.<br/>           LPDDR4: program this to tZQCAL/2 and round it up to the next integer value.<br/>           This is only present for designs supporting DDR3/DDR4 or LPDDR2/LPDDR3/LPDDR4 devices.<br/>           Programming Mode: Static</p> |
| 15:10      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9:0        | RW          | 0x040              | t_zq_short_nop<br>tZQCS for DDR3/DD4/LPDDR2/LPDDR3, tZQLAT for LPDDR4:<br>Number of DFI clock cycles of NOP required after a ZQCS (ZQ calibration short)/MPC(ZQ Latch) command is issued to SDRAM.<br>When the controller is operating in 1:2 frequency ratio mode, program this to tZQCS/2 and round it up to the next integer value.<br>This is only present for designs supporting DDR3/DDR4 or LPDDR2/LPDDR3/LPDDR4 devices.<br>Programming Mode: Static |

**DDRC\_ZQCTL1**

Address: Operational Base + offset (0x0184)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                  |
| 29:20      | RW          | 0x020              | t_zq_reset_nop<br>tZQReset: Number of DFI clock cycles of NOP required after a ZQReset (ZQ calibration Reset) command is issued to SDRAM.<br>When the controller is operating in 1:2 frequency ratio mode, program this to tZQReset/2 and round it up to the next integer value.<br>This is only present for designs supporting LPDDR2/LPDDR3/LPDDR4 devices.<br>Programming Mode: Static |
| 19:0       | RW          | 0x00100            | t_zq_short_interval_x1024<br>Average interval to wait between automatically issuing ZQCS (ZQ calibration short)/MPC(ZQ calibration) commands to DDR3/DD4/LPDDR2/LPDDR3/LPDDR4 devices.<br>Meaningless, if ZQCTL0.dis_auto_zq=1.<br>Unit: 1024 DFI clock cycles.<br>This is only present for designs supporting DDR3/DD4 or LPDDR2/LPDDR3/LPDDR4 devices.<br>Programming Mode: Static      |

**DDRC\_ZQCTL2**

Address: Operational Base + offset (0x0188)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0          | RW          | 0x0                | <p>zq_reset<br/>Setting this register bit to 1 triggers a ZQ Reset operation. When the ZQ Reset operation is complete, the uMCTL2 automatically clears this bit. It is recommended NOT to set this signal if in Init, Self-Refresh(except LPDDR4) or SRPowerdown(LPDDR4) or Deep power-down operating modes.</p> <p>This is only present for designs supporting LPDDR2/LPDDR3/LPDDR4 devices.</p> <p>Programming Mode: Dynamic</p> |

**DDRC\_ZQSTAT**

Address: Operational Base + offset (0x018c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 0          | RW          | 0x0                | <p>zq_reset_busy<br/>SoC core may initiate a ZQ Reset operation only if this signal is low. This signal goes high in the clock after the uMCTL2 accepts the ZQ Reset request. It goes low when the ZQ Reset command is issued to the SDRAM and the associated NOP period is over. It is recommended not to perform ZQ Reset commands when this signal is high.</p> <p>0: Indicates that the SoC core can initiate a ZQ Reset operation<br/>1: Indicates that ZQ Reset operation is in progress</p> <p>Programming Mode: Dynamic</p> |

**DDRC\_DFITMG0**

Address: Operational Base + offset (0x0190)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:29      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                       |
| 28:24      | RW          | 0x07               | <p>dfi_t_ctrl_delay<br/>Specifies the number of DFI clock cycles after an assertion or de-assertion 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.</p> <p>Programming Mode: Quasi-dynamic Group 4</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23         | RW          | 0x0                | <p>dfi_rddata_use_dfi_phy_clk</p> <p>Defines whether dfi_rddata_en=dfi_rddata=dfi_rddata_valid is generated using HDR (DFI clock) or SDR (DFI PHY clock) values.</p> <p>Selects whether value in DFITMG0.dfi_t_rddata_en is in terms of HDR (DFI clock) or SDR (DFI PHY clock) cycles:</p> <ul style="list-style-type: none"> <li>0: in terms of HDR (DFI clock) cycles, Only support HDR DFI clock.</li> <li>1: in terms of SDR (DFI PHY clock) cycles</li> </ul> <p>Programming Mode: Static</p>                                                                                                                  |
| 22:16      | RW          | 0x02               | <p>dfi_t_rddata_en</p> <p>Time from the assertion of a read command on the DFI interface to the assertion of the dfi_rddata_en signal. Refer to PHY specification for correct value. This corresponds to the DFI parameter trddata_en.</p> <p>Unit: DFI clock cycles</p> <p>Programming Mode: Quasi-dynamic Group 1 and Group 4</p>                                                                                                                                                                                                                                                                                 |
| 15         | RW          | 0x0                | <p>dfi_wrdata_use_dfi_phy_clk</p> <p>Defines whether dfi_wrdata_en=dfi_wrdata=dfi_wrdata_mask is generated using HDR (DFI clock) or SDR (DFI PHY clock) values</p> <p>Selects whether value in DFITMG0.dfi_tphy_wrlat is in terms of HDR (DFI clock) or SDR (DFI PHY clock) cycles</p> <p>Selects whether value in DFITMG0.dfi_tphy_wrdata is in terms of HDR (DFI clock) or SDR (DFI PHY clock) cycles</p> <ul style="list-style-type: none"> <li>0: in terms of HDR (DFI clock) cycles, Only support HDR DFI clock.</li> <li>1: in terms of SDR (DFI PHY clock) cycles</li> </ul> <p>Programming Mode: Static</p> |
| 14         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 13:8       | RW          | 0x00               | <p>dfi_tphy_wrdata</p> <p>Specifies the number of clock cycles between when dfi_wrdata_en is asserted to when the associated write data is driven on the dfi_wrdata signal. This corresponds to the DFI timing parameter tphy_wrdata. Refer to PHY specification for correct value. Note, max supported value is 8.</p> <p>Unit: DFI clock cycles.</p> <p>Programming Mode: Quasi-dynamic Group 4</p>                                                                                                                                                                                                               |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 5:0        | RW          | 0x02               | <p>dfi_tphy_wrlat</p> <p>Write latency</p> <p>Number of clocks from the write command to write data enable (dfi_wrdata_en). This corresponds to the DFI timing parameter tphy_wrlat. Refer to PHY specification for correct value.</p> <p>For LPDDR4, dfi_tphy_wrlat&gt;60 is not supported.</p> <p>Unit: DFI clock cycles</p> <p>Programming Mode: Quasi-dynamic Group 1 and Group 4</p>                                                                                                                                                                                                                           |

**DDRC DFITMG1**

Address: Operational Base + offset (0x0194)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28 | RW   | 0x0         | <p>dfi_t_cmd_lat</p> <p>Specifies the number of DFI PHY clock cycles between when the dfi_cs signal is asserted and when the associated command is driven. This field is used for CAL mode, should be set to '0' or the value which matches the CAL mode register setting in the DRAM. If the PHY can add the latency for CAL mode, this should be set to '0'.</p> <p>Valid Range: 0, 3, 4, 5, 6, and 8</p> <p>Programming Mode: Quasi-dynamic Group 2 and Group 4</p>                                            |
| 27:26 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 25:24 | RW   | 0x0         | <p>dfi_t_parin_lat</p> <p>Specifies the number of DFI PHY clock cycles between when the dfi_cs signal is asserted and when the associated dfi_parity_in signal is driven.</p> <p>Programming Mode: Quasi-dynamic Group 4</p>                                                                                                                                                                                                                                                                                      |
| 23:21 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 20:16 | RW   | 0x00        | <p>dfi_t_wrdata_delay</p> <p>Specifies the number of DFI clock cycles between when the dfi_wrdata_en signal is asserted and when the corresponding write data transfer is completed on the DRAM bus. This corresponds to the DFI timing parameter twrdata_delay. Refer to PHY specification for correct value.</p> <p>Value to be programmed is in terms of DFI clocks, not PHY clocks. In FREQ_RATIO=2, divide PHY's value by 2 and round up to next integer.</p> <p>Programming Mode: Quasi-dynamic Group 4</p> |
| 15:13 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 12:8  | RW   | 0x04        | <p>dfi_t_dram_clk_disable</p> <p>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 memory devices, at the PHY-DRAM boundary, maintains a low value. If the DFI clock and the memory clock are not phase aligned, this timing parameter should be rounded up to the next integer value.</p> <p>Programming Mode: Quasi-dynamic Group 4</p>                                                                                     |
| 7:5   | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4:0        | RW          | 0x04               | <p>dfi_t_dram_clk_enable<br/>Specifies the number of DFI clock cycles from the deassertion of the dfi_dram_clk_disable signal on the DFI until the first valid rising edge of the clock to the DRAM memory devices, at the PHY-DRAM boundary. If the DFI clock and the memory clock are not phase aligned, this timing parameter should be rounded up to the next integer value.</p> <p>Programming Mode: Quasi-dynamic Group 4</p> |

**DDRC DFILPCFG0**

Address: Operational Base + offset (0x0198)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:29      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 28:24      | RW          | 0x07               | <p>dfi_tlp_resp<br/>Setting in DFI clock cycles for DFI's tlp_resp time. Same value is used for both Power Down, Self Refresh, Deep Power Down and Maximum Power Saving modes.<br/>DFI 2.1 specification onwards, recommends using a fixed value of 7 always.</p> <p>Programming Mode: Static</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 23:20      | RW          | 0x0                | <p>dfi_lp_wakeup_dpd<br/>Value in DFI clock cycles to drive on dfi_lp_wakeup signal when Deep Power Down mode is entered.<br/>Determines the DFI's tlp_wakeup time:</p> <ul style="list-style-type: none"> <li>0x0 - 16 cycles</li> <li>0x1 - 32 cycles</li> <li>0x2 - 64 cycles</li> <li>0x3 - 128 cycles</li> <li>0x4 - 256 cycles</li> <li>0x5 - 512 cycles</li> <li>0x6 - 1024 cycles</li> <li>0x7 - 2048 cycles</li> <li>0x8 - 4096 cycles</li> <li>0x9 - 8192 cycles</li> <li>0xA - 16384 cycles</li> <li>0xB - 32768 cycles</li> <li>0xC - 65536 cycles</li> <li>0xD - 131072 cycles</li> <li>0xE - 262144 cycles</li> <li>0xF - Unlimited</li> </ul> <p>This is only present for designs supporting mDDR or LPDDR2/LPDDR3 devices.</p> <p>Programming Mode: Static</p> |
| 19:17      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16         | RW          | 0x0                | <p>dfi_lp_en_dpd<br/>Enables DFI Low Power interface handshaking during Deep Power Down Entry/Exit.<br/>0 - Disabled; 1 - Enabled<br/>This is only present for designs supporting mDDR or LPDDR2/LPDDR3 devices.<br/>Programming Mode: Static</p>                                                                                                                                                                                                                                                                                                            |
| 15:12      | RW          | 0x0                | <p>dfi_lp_wakeup_sr<br/>Value in DFI clpck cycles to drive on dfi_lp_wakeup signal when Self Refresh mode is entered.<br/>Determines the DFI's tlp_wakeup time:<br/>0x0 - 16 cycles<br/>0x1 - 32 cycles<br/>0x2 - 64 cycles<br/>0x3 - 128 cycles<br/>0x4 - 256 cycles<br/>0x5 - 512 cycles<br/>0x6 - 1024 cycles<br/>0x7 - 2048 cycles<br/>0x8 - 4096 cycles<br/>0x9 - 8192 cycles<br/>0xA - 16384 cycles<br/>0xB - 32768 cycles<br/>0xC - 65536 cycles<br/>0xD - 131072 cycles<br/>0xE - 262144 cycles<br/>0xF - Unlimited<br/>Programming Mode: Static</p> |
| 11:9       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 8          | RW          | 0x0                | <p>dfi_lp_en_sr<br/>Enables DFI Low Power interface handshaking during Self Refresh Entry/Exit.<br/>0 - Disabled; 1 - Enabled<br/>Programming Mode: Static</p>                                                                                                                                                                                                                                                                                                                                                                                               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:4        | RW          | 0x0                | <p>dfi_lp_wakeup_pd<br/>Value in DFI clock cycles to drive on dfi_lp_wakeup signal when Power Down mode is entered.<br/>Determines the DFI's tlp_wakeup time:</p> <ul style="list-style-type: none"> <li>0x0 - 16 cycles</li> <li>0x1 - 32 cycles</li> <li>0x2 - 64 cycles</li> <li>0x3 - 128 cycles</li> <li>0x4 - 256 cycles</li> <li>0x5 - 512 cycles</li> <li>0x6 - 1024 cycles</li> <li>0x7 - 2048 cycles</li> <li>0x8 - 4096 cycles</li> <li>0x9 - 8192 cycles</li> <li>0xA - 16384 cycles</li> <li>0xB - 32768 cycles</li> <li>0xC - 65536 cycles</li> <li>0xD - 131072 cycles</li> <li>0xE - 262144 cycles</li> <li>0xF - Unlimited</li> </ul> <p>Programming Mode: Static</p> |
| 3:1        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 0          | RW          | 0x0                | <p>dfi_lp_en_pd<br/>Enables DFI Low Power interface handshaking during Power Down Entry/Exit.<br/>0: Disabled; 1: Enabled<br/>Programming Mode: Static</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

**DDRC DFILPCFG1**

Address: Operational Base + offset (0x019c)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:4        | RW          | 0x0                | <p>dfi_lp_wakeup_mpsm<br/> Value in DFI clock cycles to drive on dfi_lp_wakeup signal when Maximum Power Saving Mode is entered.<br/> Determines the DFI's tlp_wakeup time:</p> <ul style="list-style-type: none"> <li>0x0 - 16 cycles</li> <li>0x1 - 32 cycles</li> <li>0x2 - 64 cycles</li> <li>0x3 - 128 cycles</li> <li>0x4 - 256 cycles</li> <li>0x5 - 512 cycles</li> <li>0x6 - 1024 cycles</li> <li>0x7 - 2048 cycles</li> <li>0x8 - 4096 cycles</li> <li>0x9 - 8192 cycles</li> <li>0xA - 16384 cycles</li> <li>0xB - 32768 cycles</li> <li>0xC - 65536 cycles</li> <li>0xD - 131072 cycles</li> <li>0xE - 262144 cycles</li> <li>0xF - Unlimited</li> </ul> <p>This is only present for designs supporting DDR4 devices.<br/> Programming Mode: Static</p> |
| 3:1        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 0          | RW          | 0x0                | <p>dfi_lp_en_mpsm<br/> Enables DFI Low Power interface handshaking during Maximum Power Saving Mode Entry/Exit.<br/> 0 - Disabled; 1 - Enabled<br/> This is only present for designs supporting DDR4 devices.<br/> Programming Mode: Static</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

**DDRC\_DFIUPDO**

Address: Operational Base + offset (0x01a0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RW          | 0x0                | <p>dis_auto_ctrlupd<br/> When '1', disable the automatic dfi_ctrlupd_req generation by the uMCTL2. The core must issue the dfi_ctrlupd_req signal using register DBGCMD.ctrlupd. When '0', uMCTL2 issues dfi_ctrlupd_req periodically.<br/> Programming Mode: Quasi-dynamic Group 3</p> |
| 30         | RW          | 0x0                | <p>dis_auto_ctrlupd_srx<br/> When '1', disable the automatic dfi_ctrlupd_req generation by the uMCTL2 at self-refresh exit. When '0', uMCTL2 issues a dfi_ctrlupd_req before or after exiting self-refresh, depending on DFIUPD0.ctrlupd_pre_srx.<br/> Programming Mode: Static</p>     |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 29         | RW          | 0x0                | <p>ctrlupd_pre_srx<br/>Selects dfi_ctrlupd_req requirements at SRX:<br/>0 : send ctrlupd after SRX<br/>1 : send ctrlupd before SRX If DFIUPD0.dis_auto_ctrlupd_srx=1, this register has no impact, because no dfi_ctrlupd_req will be issued when SRX.<br/>Programming Mode: Static</p>                                                                                       |
| 28:26      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                      |
| 25:16      | RW          | 0x040              | <p>dfi_t_ctrlup_max<br/>Specifies the maximum number of DFI clock cycles that the dfi_ctrlupd_req signal can assert. Lowest value to assign to this variable is 0x40.<br/>Programming Mode: Static</p>                                                                                                                                                                        |
| 15:10      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                      |
| 9:0        | RW          | 0x003              | <p>dfi_t_ctrlup_min<br/>Specifies the minimum number of DFI clock cycles that the dfi_ctrlupd_req signal must be asserted. The uMCTL2 expects the PHY to respond within this time. If the PHY does not respond, the uMCTL2 will de-assert dfi_ctrlupd_req after dfi_t_ctrlup_min + 2 cycles. Lowest value to assign to this variable is 0x3.<br/>Programming Mode: Static</p> |

**DDRC\_DFIUPD1**

Address: Operational Base + offset (0x01a4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 23:16      | RW          | 0x00               | <p>dfi_t_ctrlupd_interval_min_x1024<br/>This is the minimum amount of time between uMCTL2 initiated DFI update requests (which is executed whenever the uMCTL2 is idle). Set this number higher to reduce the frequency of update requests, which can have a small impact on the latency of the first read request when the uMCTL2 is idle. Minimum allowed value for this field is 1.<br/>Unit: 1024 DFI clock cycles<br/>Programming Mode: Static</p> |
| 15:8       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0        | RW          | 0x01               | <p>dfi_t_ctrlupd_interval_max_x1024<br/> This is the maximum amount of time between uMCTL2 initiated DFI update requests. This timer resets with each update request; when the timer expires dfi_ctrlupd_req is sent and traffic is blocked until the dfi_ctrlupd_ackx is received. PHY can use this idle time to recalibrate the delay lines to the DLLs. The DFI controller update is also used to reset PHY FIFO pointers in case of data capture errors. Updates are required to maintain calibration over PVT, but frequent updates may impact performance. Minimum allowed value for this field is 1.</p> <p>Note: Value programmed for DFIUPD1.dfi_t_ctrlupd_interval_max_x1024 must be greater than DFIUPD1.dfi_t_ctrlupd_interval_min_x1024.</p> <p>Unit: 1024 DFI clock cycles<br/> Programming Mode: Static</p> |

**DDRC DFIUPD2**

Address: Operational Base + offset (0x01a8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x0                | reserved                                                                                                                                            |
| 0          | RW          | 0x1                | <p>dfi_phyupd_en<br/> Enables the support for acknowledging PHY-initiated updates:<br/> 0 - Disabled; 1 - Enabled<br/> Programming Mode: Static</p> |

**DDRC DFIMISC**

Address: Operational Base + offset (0x01b0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:13      | RO          | 0x0                | reserved                                                                                                                                                                                                                                           |
| 12:8       | RW          | 0x00               | <p>dfi_frequency<br/> Indicates the operating frequency of the system. The number of supported frequencies and the mapping of signal values to clock frequencies are defined by the PHY.<br/> Programming Mode: Quasi-dynamic Group 1</p>          |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                                                                           |
| 5          | RW          | 0x0                | <p>dfi_init_start<br/> PHY init start request signal. When asserted it triggers the PHY init start request<br/> Programming Mode: Quasi-dynamic Group 3</p>                                                                                        |
| 4          | RW          | 0x0                | <p>ctl_idle_en<br/> Enables support of ctl_idle signal, which is non-DFI related pin specific to certain Synopsys PHYs. See signal description of ctl_idle signal for further details of ctl_idle functionality.<br/> Programming Mode: Static</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3          | RW          | 0x0                | <p>share_dfi_dram_clk_disable<br/>Indicate dfi_dram_clk_disable is shared for two channels or not.<br/>1: Share mode<br/>0: Not share.</p> <p>In Shared mode, Controller does not request PHY stop clock while any rank of any channel has not disable clock. Note: when dfi_dram_clk_disable is shared by two channels, an additional DFF is inserted, that will cause dram clock enable is delay one cycle.</p> <p>Suggest set dfi_t_dram_clk_enable value to Tdram_clk_enable+1. Tdram_clk_enable value is from PHY, which indicate how many cycles from dfi_dram_clk_disable de-assert to dram clock output.</p> <p>Programming Mode: Static</p> |
| 2          | RW          | 0x0                | <p>dfi_data_cs_polarity<br/>Defines polarity of dfi_wrdata_cs and dfi_rddata_cs signals.<br/>0: Signals are active low; 1: Signals are active high</p> <p>Programming Mode: Static</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 1          | RW          | 0x0                | <p>phy_dbm_mode<br/>DBI implemented in DDRC or PHY.<br/>0 - DDRC implements DBI functionality.<br/>1 - PHY implements DBI functionality. Present only in designs configured to support DDR4 and LPDDR4.</p> <p>Programming Mode: Static</p>                                                                                                                                                                                                                                                                                                                                                                                                          |
| 0          | RW          | 0x1                | <p>dfi_init_complete_en<br/>PHY initialization complete enable signal. When asserted the dfi_init_complete signal can be used to trigger SDRAM initialisation</p> <p>Programming Mode: Quasi-dynamic Group 3</p>                                                                                                                                                                                                                                                                                                                                                                                                                                     |

**DDRC\_DFITMG2**

Address: Operational Base + offset (0x01b4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:15      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                  |
| 14:8       | RW          | 0x02               | <p>dfi_tphy_rdcslat<br/>Number of DFI PHY clock cycles between when a read command is sent on the DFI control interface and when the associated dfi_rddata_cs signal is asserted. This corresponds to the DFI timing parameter tphy_rdcslat. Refer to PHY specification for correct value.</p> <p>Programming Mode: Quasi-dynamic Group 2 and Group 4</p> |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5:0        | RW          | 0x02               | <p>dfi_tphy_wrcslat<br/>Number of DFI PHY clock cycles between when a write command is sent on the DFI control interface and when the associated dfi_wrdata_cs signal is asserted. This corresponds to the DFI timing parameter tphy_wrcslat. Refer to PHY specification for correct value.</p> <p>Programming Mode: Quasi-dynamic Group 2 and Group 4</p> |

**DDRC DFITMG3**

Address: Operational Base + offset (0x01b8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                 |
| 4:0        | RW          | 0x00               | <p>dfi_t_geardown_delay<br/>The delay from dfi_geardown_en assertion to the time of the PHY being ready to receive commands. Refer to PHY specification for correct value.</p> <p>When the controller is operating in 1:2 frequency ratio mode, program this to (tardown_delay/2) and round it up to the next integer value.</p> <p>Unit: DFI Clocks</p> <p>Programming Mode: Static</p> |

**DDRC DFISTAT**

Address: Operational Base + offset (0x01bc)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                      |
| 1          | RW          | 0x0                | <p>dfi_lp_ack<br/>Stores the value of the dfi_lp_ack input to the controller.</p> <p>Programming Mode: Dynamic</p>                                                                                                                                                                            |
| 0          | RO          | 0x0                | <p>dfi_init_complete<br/>The status flag register which announces when the DFI initialization has been completed. The DFI INIT triggered by dfi_init_start signal and then the dfi_init_complete flag is polled to know when the initialization is done.</p> <p>Programming Mode: Dynamic</p> |

**DDRC DBICTL**

Address: Operational Base + offset (0x01c0)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2          | RW          | 0x0                | <p>rd_db_i_en<br/>Read DBI enable signal in DDRC.<br/>0 - Read DBI is disabled.<br/>1 - Read DBI is enabled.</p> <p>This signal must be set the same value as DRAM's mode register.<br/>DDR4: MR5 bit A12. When x4 devices are used, this signal must be set to 0.<br/>LPDDR4: MR3[6]</p> <p>Programming Mode: Quasi-dynamic Group 1</p>                                                                                      |
| 1          | RW          | 0x0                | <p>wr_db_i_en<br/>Write DBI enable signal in DDRC.<br/>0 - Write DBI is disabled.<br/>1 - Write DBI is enabled.</p> <p>This signal must be set the same value as DRAM's mode register.<br/>DDR4: MR5 bit A11. When x4 devices are used, this signal must be set to 0.<br/>LPDDR4: MR3[7]</p> <p>Programming Mode: Quasi-dynamic Group 1</p>                                                                                   |
| 0          | RW          | 0x1                | <p>dm_en<br/>DM enable signal in DDRC.<br/>0 - DM is disabled; 1 - DM is enabled.</p> <p>This signal must be set the same logical value as DRAM's mode register.</p> <p>DDR4: Set this to same value as MR5 bit A10. When x4 devices are used, this signal must be set to 0.<br/>LPDDR4: Set this to inverted value of MR13[5] which is opposite polarity from this signal</p> <p>Programming Mode: Quasi-dynamic Group 3</p> |

**DDRC DFIPHYMSTR**

Address: Operational Base + offset (0x01c4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x0                | reserved                                                                                                                   |
| 0          | RW          | 0x1                | <p>dfi_phymstr_en<br/>Enables the PHY Master Interface:<br/>0 - Disabled; 1 - Enabled</p> <p>Programming Mode: Dynamic</p> |

**DDRC ADDRMAP0**

Address: Operational Base + offset (0x0200)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 20:16      | RW          | 0x00               | <p>addrmap_dch_bit0<br/>Selects the HIF address bit used as data channel address bit 0.<br/>Valid Range: 0 to 30, and 31 (Traffic constraints apply based on the register value when UMCTL2_EXCL_ACCESS&gt;0.<br/>See Exclusive Access section for details.)<br/>Internal Base: 2<br/>The selected address bit is determined by adding the internal base to the value of this field. If unused, set to 31 and then channel bit is set to 0.<br/>Programming Mode: Static</p> |
| 15:13      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 12:8       | RW          | 0x00               | <p>addrmap_cs_bit1<br/>Selects the HIF address bit used as rank address bit 1. Valid Range: 0 to 28, and 31<br/>Internal Base: 7<br/>The selected HIF address bit is determined by adding the internal base to the value of this field. If unused, set to 31 and then rank address bit 1 is set to 0.<br/>Programming Mode: Static</p>                                                                                                                                       |
| 7:5        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 4:0        | RW          | 0x00               | <p>addrmap_cs_bit0<br/>Selects the HIF address bit used as rank address bit 0. Valid Range: 0 to 29, and 31<br/>Internal Base: 6<br/>The selected HIF address bit is determined by adding the internal base to the value of this field. If unused, set to 31 and then rank address bit 0 is set to 0.<br/>Programming Mode: Static</p>                                                                                                                                       |

**DDRC ADDRMAP1**

Address: Operational Base + offset (0x0204)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:22      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                              |
| 21:16      | RW          | 0x00               | <p>addrmap_bank_b2<br/>Selects the HIF address bit used as bank address bit 2. Valid Range: 0 to 31 and 63<br/>Internal Base: 4<br/>The selected HIF address bit is determined by adding the internal base to the value of this field. If unused, set to 63 and then bank address bit 2 is set to 0.<br/>Programming Mode: Static</p> |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                              |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:8       | RW          | 0x00               | <p>addrmap_bank_b1<br/>Selects the HIF address bits used as bank address bit 1. Valid Range: 0 to 32 and 63<br/>Internal Base: 3<br/>The selected HIF address bit for each of the bank address bits is determined by adding the internal base to the value of this field. If unused, set to 63 and then bank address bit 1 is set to 0.<br/>Programming Mode: Static</p> |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                 |
| 5:0        | RW          | 0x00               | <p>addrmap_bank_b0<br/>Selects the HIF address bits used as bank address bit 0. Valid Range: 0 to 32 and 63<br/>Internal Base: 2<br/>The selected HIF address bit for each of the bank address bits is determined by adding the internal base to the value of this field. If unused, set to 63 and then bank address bit 0 is set to 0.<br/>Programming Mode: Static</p> |

**DDRC\_ADDRMAP2**

Address: Operational Base + offset (0x0208)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 27:24      | RW          | 0x0                | <p>addrmap_col_b5<br/>Full bus width mode: Selects the HIF address bit used as column address bit 5.<br/>Half bus width mode: Selects the HIF address bit used as column address bit 6.<br/>Valid Range: 0 to 7, and 15<br/>Internal Base: 5<br/>The selected HIF address bit is determined by adding the internal base to the value of this field. If unused, set to 15 and then this column address bit is set to 0.<br/>Programming Mode: Static</p> |
| 23:20      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 19:16      | RW          | 0x0                | <p>addrmap_col_b4<br/>Full bus width mode: Selects the HIF address bit used as column address bit 4.<br/>Half bus width mode: Selects the HIF address bit used as column address bit 5.<br/>Valid Range: 0 to 7, and 15<br/>Internal Base: 4<br/>The selected HIF address bit is determined by adding the internal base to the value of this field. If unused, set to 15 and then this column address bit is set to 0.<br/>Programming Mode: Static</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:12      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 11:8       | RW          | 0x0                | <p>addrmap_col_b3<br/>           Full bus width mode: Selects the HIF address bit used as column address bit 3.<br/>           Half bus width mode: Selects the HIF address bit used as column address bit 4.<br/>           Valid Range: 0 to 7<br/>           Internal Base: 3<br/>           The selected HIF address bit is determined by adding the internal base to the value of this field.<br/>           Note, if UMCTL2_INCL_ARB=1, MEMC_BURST_LENGTH=16, Full bus width (MSTR.data_bus_width=00) and BL16 (MSTR.burst_rdwr=1000), it is recommended to program this to 0.<br/>           Programming Mode: Static</p> |
| 7:4        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0        | RW          | 0x0                | <p>addrmap_col_b2</p> <p>Full bus width mode: Selects the HIF address bit used as column address bit 2.</p> <p>Half bus width mode: Selects the HIF address bit used as column address bit 3.</p> <p>Valid Range: 0 to 7</p> <p>Internal Base: 2</p> <p>The selected HIF address bit is determined by adding the internal base to the value of this field.</p> <p>Note, if UMCTL2_INCL_ARB=1 and MEMC_BURST_LENGTH=8, it is required to program this to 0 unless:</p> <ul style="list-style-type: none"> <li>in Half or Quarter bus width (MSTR.data_bus_width!=00) and PCCFG.bl_exp_mode==1 and either           <ul style="list-style-type: none"> <li>In DDR4 and ADDRMAP8.addrmap_bg_b0==0 or</li> <li>In LPDDR4 and ADDRMAP1.addrmap_bank_b0==0</li> </ul> </li> <li>If UMCTL2_INCL_ARB=1 and MEMC_BURST_LENGTH=16, it is required to program this to 0 unless:           <ul style="list-style-type: none"> <li>in Half or Quarter bus width (MSTR.data_bus_width!=00) and PCCFG.bl_exp_mode==1 and               <ul style="list-style-type: none"> <li>In DDR4 and ADDRMAP8.addrmap_bg_b0==0</li> </ul> </li> <li>Otherwise, if MEMC_BURST_LENGTH=8 and Full Bus Width (MSTR.data_bus_width==00), it is recommended to program this to 0 so that HIF[2] maps to column address bit 2.</li> <li>If MEMC_BURST_LENGTH=16 and Full Bus Width (MSTR.data_bus_width==00), it is recommended to program this to 0 so that HIF[2] maps to column address bit 2.</li> <li>If MEMC_BURST_LENGTH=16 and Half Bus Width (MSTR.data_bus_width==01), it is recommended to program this to 0 so that HIF[2] maps to column address bit 3.</li> </ul> </li> </ul> <p>Programming Mode: Static</p> |

**DDRC ADDRMAP3**

Address: Operational Base + offset (0x020c)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 28:24      | RW          | 0x00               | <p>addrmap_col_b9</p> <p>Full bus width mode: Selects the HIF address bit used as column address bit 9.</p> <p>Half bus width mode: Selects the HIF address bit used as column address bit 11 (10 in LPDDR2/LPDDR3 mode).</p> <p>Valid Range: 0 to 7, and 31.</p> <p>Internal Base: 9</p> <p>The selected HIF address bit is determined by adding the internal base to the value of this field. If unused, set to 31 and then this column address bit is set to 0.</p> <p>Note: Per JEDEC DDR2/3/mDDR specification, column address bit 10 is reserved for indicating auto-precharge, and hence no source address bit can be mapped to column address bit 10. In LPDDR2/LPDDR3, there is a dedicated bit for autoprecharge in the CA bus and hence column bit 10 is used.</p> <p>Programming Mode: Static</p> |
| 23:21      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 20:16      | RW          | 0x00               | <p>addrmap_col_b8</p> <p>Full bus width mode: Selects the HIF address bit used as column address bit 8.</p> <p>Half bus width mode: Selects the HIF address bit used as column address bit 9.</p> <p>Valid Range: 0 to 7, and 31.</p> <p>Internal Base: 8</p> <p>The selected HIF address bit is determined by adding the internal base to the value of this field. If unused, set to 31 and then this column address bit is set to 0.</p> <p>Note: Per JEDEC DDR2/3/mDDR specification, column address bit 10 is reserved for indicating auto-precharge, and hence no source address bit can be mapped to column address bit 10. In LPDDR2/LPDDR3, there is a dedicated bit for autoprecharge in the CA bus and hence column bit 10 is used.</p> <p>Programming Mode: Static</p>                             |
| 15:13      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 12:8       | RW          | 0x00               | <p>addrmap_col_b7</p> <p>Full bus width mode: Selects the HIF address bit used as column address bit 7.</p> <p>Half bus width mode: Selects the HIF address bit used as column address bit 8.</p> <p>Valid Range: 0 to 7, and 31.</p> <p>Internal Base: 7</p> <p>The selected HIF address bit is determined by adding the internal base to the value of this field. If unused, set to 31 and then this column address bit is set to 0.</p> <p>Programming Mode: Static</p>                                                                                                                                                                                                                                                                                                                                    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:4        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 3:0        | RW          | 0x0                | <p>addrmap_col_b6<br/>           Full bus width mode: Selects the HIF address bit used as column address bit 6.<br/>           Half bus width mode: Selects the HIF address bit used as column address bit 7.<br/>           Valid Range: 0 to 7, and 15<br/>           Internal Base: 6<br/>           The selected HIF address bit is determined by adding the internal base to the value of this field. If unused, set to 15 and then this column address bit is set to 0.<br/>           Programming Mode: Static</p> |

**DDRC ADDRMAP4**

Address: Operational Base + offset (0x0210)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:13      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 12:8       | RW          | 0x00               | <p>addrmap_col_b11<br/>           Full bus width mode: Selects the HIF address bit used as column address bit 13 (11 in LPDDR2/LPDDR3 mode).<br/>           Half bus width mode: Unused. To make it unused, this should be tied to 4'hF.<br/>           Valid Range: 0 to 7, and 31.<br/>           Internal Base: 11<br/>           The selected HIF address bit is determined by adding the internal base to the value of this field. If unused, set to 31 and then this column address bit is set to 0.<br/>           Note: Per JEDEC DDR2/3/mDDR specification, column address bit 10 is reserved for indicating auto-precharge, and hence no source address bit can be mapped to column address bit 10. In LPDDR2/LPDDR3, there is a dedicated bit for autoprecharge in the CA bus and hence column bit 10 is used.<br/>           Programming Mode: Static</p> |
| 7:5        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4:0        | RW          | 0x00               | <p>addrmap_col_b10<br/> Full bus width mode: Selects the HIF address bit used as column address bit 11 (10 in LPDDR2/LPDDR3 mode).<br/> Half bus width mode: Selects the HIF address bit used as column address bit 13 (11 in LPDDR2/LPDDR3 mode).<br/> Valid Range: 0 to 7, and 31.<br/> Internal Base: 10</p> <p>The selected HIF address bit is determined by adding the internal base to the value of this field. If unused, set to 31 and then this column address bit is set to 0.</p> <p>Note: Per JEDEC DDR2/3/mDDR specification, column address bit 10 is reserved for indicating auto-precharge, and hence no source address bit can be mapped to column address bit 10. In LPDDR2/LPDDR3, there is a dedicated bit for autoprecharge in the CA bus and hence column bit 10 is used.</p> <p>Programming Mode: Static</p> |

**DDRC ADDRMAP5**

Address: Operational Base + offset (0x0214)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 27:24      | RW          | 0x0                | <p>addrmap_row_b11<br/> Selects the HIF address bit used as row address bit 11.<br/> Valid Range: 0 to 11, and 15<br/> Internal Base: 17</p> <p>The selected HIF address bit is determined by adding the internal base to the value of this field. If unused, set to 15 and then row address bit 11 is set to 0.</p> <p>Programming Mode: Static</p>                                                                                                                                                                                                                               |
| 23:20      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 19:16      | RW          | 0x0                | <p>addrmap_row_b2_10<br/> Selects the HIF address bits used as row address bits 2 to 10.<br/> Valid Range: 0 to 11, and 15<br/> Internal Base: 8 (for row address bit 2), 9 (for row address bit 3), 10 (for row address bit 4) etc increasing to 16 (for row address bit 10)</p> <p>The selected HIF address bit for each of the row address bits is determined by adding the internal base to the value of this field. When value 15 is used the values of row address bits 2 to 10 are defined by registers ADDRMAP9, ADDRMAP10, ADDRMAP11.</p> <p>Programming Mode: Static</p> |
| 15:12      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11:8       | RW          | 0x0                | <p>addrmap_row_b1<br/>Selects the HIF address bits used as row address bit 1.<br/>Valid Range: 0 to 11<br/>Internal Base: 7<br/>The selected HIF address bit for each of the row address bits is determined by adding the internal base to the value of this field.<br/>Programming Mode: Static</p> |
| 7:4        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                             |
| 3:0        | RW          | 0x0                | <p>addrmap_row_b0<br/>Selects the HIF address bits used as row address bit 0.<br/>Valid Range: 0 to 11<br/>Internal Base: 6<br/>The selected HIF address bit for each of the row address bits is determined by adding the internal base to the value of this field.<br/>Programming Mode: Static</p> |

**DDRC ADDRMAP6**

Address: Operational Base + offset (0x0218)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RW          | 0x0                | <p>lpddr3_6gb_12gb<br/>Set this to 1 if there is an LPDDR3 SDRAM 6Gb or 12Gb device in use.<br/>1 - LPDDR3 SDRAM 6Gb/12Gb device in use. Every address having row[14:13]==2'b11 is considered as invalid<br/>0 - non-LPDDR3 6Gb/12Gb device in use. All addresses are valid<br/>Present only in designs configured to support LPDDR3.<br/>Programming Mode: Static</p>                                                                                                                                                                      |
| 30:29      | RW          | 0x0                | <p>lpddr4_6gb_12gb_24gb<br/>Indicates what type of LPDDR4 SDRAM device is in use.<br/>2'b00: No LPDDR4 SDRAM 6Gb/12Gb/24Gb device in use. All addresses are valid<br/>2'b01: LPDDR4 SDRAM 6Gb device in use. Every address having row[14:13]==2'b11 is considered as invalid<br/>2'b10: LPDDR4 SDRAM 12Gb device in use. Every address having row[15:14]==2'b11 is considered as invalid<br/>2'b11: LPDDR4 SDRAM 24Gb device in use. Unsupported<br/>Present only in designs configured to support LPDDR4.<br/>Programming Mode: Static</p> |
| 28         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 27:24      | RW          | 0x0                | <p>addrmap_row_b15<br/>Selects the HIF address bit used as row address bit 15.<br/>Valid Range: 0 to 11, and 15<br/>Internal Base: 21<br/>The selected HIF address bit is determined by adding the internal base to the value of this field. If unused, set to 15 and then row address bit 15 is set to 0.<br/>Programming Mode: Static</p> |
| 23:20      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                    |
| 19:16      | RW          | 0x0                | <p>addrmap_row_b14<br/>Selects the HIF address bit used as row address bit 14.<br/>Valid Range: 0 to 11, and 15<br/>Internal Base: 20<br/>The selected HIF address bit is determined by adding the internal base to the value of this field. If unused, set to 15 and then row address bit 14 is set to 0.<br/>Programming Mode: Static</p> |
| 15:12      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                    |
| 11:8       | RW          | 0x0                | <p>addrmap_row_b13<br/>Selects the HIF address bit used as row address bit 13.<br/>Valid Range: 0 to 11, and 15<br/>Internal Base: 19<br/>The selected HIF address bit is determined by adding the internal base to the value of this field. If unused, set to 15 and then row address bit 13 is set to 0.<br/>Programming Mode: Static</p> |
| 7:4        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                    |
| 3:0        | RW          | 0x0                | <p>addrmap_row_b12<br/>Selects the HIF address bit used as row address bit 12.<br/>Valid Range: 0 to 11, and 15<br/>Internal Base: 18<br/>The selected HIF address bit is determined by adding the internal base to the value of this field. If unused, set to 15 and then row address bit 12 is set to 0.<br/>Programming Mode: Static</p> |

**DDRC\_ADDRMAP7**

Address: Operational Base + offset (0x021c)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11:8       | RW          | 0x0                | <p>addrmap_row_b17<br/>Selects the HIF address bit used as row address bit 17.<br/>Valid Range: 0 to 11, and 15<br/>Internal Base: 23<br/>The selected HIF address bit is determined by adding the internal base to the value of this field. If unused, set to 15 and then row address bit 17 is set to 0.<br/>Programming Mode: Static</p> |
| 7:4        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                    |
| 3:0        | RW          | 0x0                | <p>addrmap_row_b16<br/>Selects the HIF address bit used as row address bit 16.<br/>Valid Range: 0 to 11, and 15<br/>Internal Base: 22<br/>The selected HIF address bit is determined by adding the internal base to the value of this field. If unused, set to 15 and then row address bit 16 is set to 0.<br/>Programming Mode: Static</p> |

**DDRC\_ADDRMAP8**

Address: Operational Base + offset (0x0220)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                      |
| 13:8       | RW          | 0x00               | <p>addrmap_bg_b1<br/>Selects the HIF address bits used as bank group address bit 1.<br/>Valid Range: 0 to 32, and 63<br/>Internal Base: 3<br/>The selected HIF address bit for each of the bank group address bits is determined by adding the internal base to the value of this field. If unused, set to 63 and then bank group address bit 1 is set to 0.<br/>Programming Mode: Static</p> |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                      |
| 5:0        | RW          | 0x00               | <p>addrmap_bg_b0<br/>Selects the HIF address bits used as bank group address bit 0.<br/>Valid Range: 0 to 32 and 63<br/>Internal Base: 2<br/>The selected HIF address bit for each of the bank group address bits is determined by adding the internal base to the value of this field. If unused, set to 63 and then bank group address bit 0 is set to 0.<br/>Programming Mode: Static</p>  |

**DDRC\_ADDRMAP9**

Address: Operational Base + offset (0x0224)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                          |
| 27:24      | RW          | 0x0                | <p>addrmap_row_b5<br/>Selects the HIF address bits used as row address bit 5.<br/>Valid Range: 0 to 11<br/>Internal Base: 11</p> <p>The selected HIF address bit for each of the row address bits is determined by adding the internal base to the value of this field.<br/>This register field is used only when ADDRMAP5.addrmap_row_b2_10 is set to value 15.<br/>Programming Mode: Static</p> |
| 23:20      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                          |
| 19:16      | RW          | 0x0                | <p>addrmap_row_b4<br/>Selects the HIF address bits used as row address bit 4.<br/>Valid Range: 0 to 11<br/>Internal Base: 10</p> <p>The selected HIF address bit for each of the row address bits is determined by adding the internal base to the value of this field.<br/>This register field is used only when ADDRMAP5.addrmap_row_b2_10 is set to value 15.<br/>Programming Mode: Static</p> |
| 15:12      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                          |
| 11:8       | RW          | 0x0                | <p>addrmap_row_b3<br/>Selects the HIF address bits used as row address bit 3.<br/>Valid Range: 0 to 11<br/>Internal Base: 9</p> <p>The selected HIF address bit for each of the row address bits is determined by adding the internal base to the value of this field.<br/>This register field is used only when ADDRMAP5.addrmap_row_b2_10 is set to value 15.<br/>Programming Mode: Static</p>  |
| 7:4        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                          |
| 3:0        | RW          | 0x0                | <p>addrmap_row_b2<br/>Selects the HIF address bits used as row address bit 2.<br/>Valid Range: 0 to 11<br/>Internal Base: 8</p> <p>The selected HIF address bit for each of the row address bits is determined by adding the internal base to the value of this field.<br/>This register field is used only when ADDRMAP5.addrmap_row_b2_10 is set to value 15.<br/>Programming Mode: Static</p>  |

**DDRC ADDRMAP10**

Address: Operational Base + offset (0x0228)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 27:24      | RW          | 0x0                | <p>addrmap_row_b9<br/>Selects the HIF address bits used as row address bit 9.<br/>Valid Range: 0 to 11<br/>Internal Base: 15</p> <p>The selected HIF address bit for each of the row address bits is determined by adding the internal base to the value of this field. This register field is used only when ADDRMAP5.addrmap_row_b2_10 is set to value 15.</p> <p>Programming Mode: Static</p> |
| 23:20      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                         |
| 19:16      | RW          | 0x0                | <p>addrmap_row_b8<br/>Selects the HIF address bits used as row address bit 8.<br/>Valid Range: 0 to 11<br/>Internal Base: 14</p> <p>The selected HIF address bit for each of the row address bits is determined by adding the internal base to the value of this field. This register field is used only when ADDRMAP5.addrmap_row_b2_10 is set to value 15.</p> <p>Programming Mode: Static</p> |
| 15:12      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                         |
| 11:8       | RW          | 0x0                | <p>addrmap_row_b7<br/>Selects the HIF address bits used as row address bit 7.<br/>Valid Range: 0 to 11<br/>Internal Base: 13</p> <p>The selected HIF address bit for each of the row address bits is determined by adding the internal base to the value of this field. This register field is used only when ADDRMAP5.addrmap_row_b2_10 is set to value 15.</p> <p>Programming Mode: Static</p> |
| 7:4        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                         |
| 3:0        | RW          | 0x0                | <p>addrmap_row_b6<br/>Selects the HIF address bits used as row address bit 6.<br/>Valid Range: 0 to 11<br/>Internal Base: 12</p> <p>The selected HIF address bit for each of the row address bits is determined by adding the internal base to the value of this field. This register field is used only when ADDRMAP5.addrmap_row_b2_10 is set to value 15.</p> <p>Programming Mode: Static</p> |

**DDRC ADDRMAP11**

Address: Operational Base + offset (0x022c)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0        | RW          | 0x0                | <p>addrmap_row_b10<br/>Selects the HIF address bits used as row address bit 10.<br/>Valid Range: 0 to 11<br/>Internal Base: 16</p> <p>The selected HIF address bit for each of the row address bits is determined by adding the internal base to the value of this field. This register field is used only when ADDRMAP5.addrmap_row_b2_10 is set to value 15.</p> <p>Programming Mode: Static</p> |

**DDRC\_ODTCFG**

Address: Operational Base + offset (0x0240)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 27:24      | RW          | 0x4                | <p>wr_odt_hold<br/>DFI PHY clock cycles to hold ODT for a write command. The minimum supported value is 2.<br/>Recommended values:<br/>DDR2: BL8: 0x5 (DDR2-400/533/667), 0x6 (DDR2-800), 0x7(DDR2-1066); BL4: 0x3 (DDR2-400/533/667), 0x4 (DDR2-800), 0x5 (DDR2-1066)<br/>DDR3: BL8: 0x6<br/>DDR4: BL8: 5 + WR_PREAMBLE + CRC_MODE. WR_PREAMBLE = 1 (1tCK write preamble), 2 (2tCK write preamble). CRC_MODE = 0 (not CRC mode), 1 (CRC mode)<br/>LPDDR3: BL8: 7 + RU(tODTon(max)/tCK)<br/>Programming Mode: Quasi-dynamic Group 1 and Group 4</p>                                                           |
| 23:21      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 20:16      | RW          | 0x00               | <p>wr_odt_delay<br/>The delay, in DFI PHY clock cycles, from issuing a write command to setting ODT values associated with that command. ODT setting must remain constant for the entire time that DQS is driven by the uMCTL2.<br/>Recommended values:<br/>DDR2: CWL + AL - 3 (DDR2-400/533/667), CWL + AL - 4 (DDR2-800), CWL + AL - 5 (DDR2-1066). If (CWL + AL - 3 &lt; 0), uMCTL2 does not support ODT for write operation.<br/>DDR3: 0x0<br/>DDR4: DFITMG1.dfi_t_cmd_lat (to adjust for CAL mode)<br/>LPDDR3: WL - 1 - RU(tODTon(max)/tCK))<br/>Programming Mode: Quasi-dynamic Group 1 and Group 4</p> |
| 15:12      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11:8       | RW          | 0x4                | <p>rd_odt_hold<br/>DFI PHY clock cycles to hold ODT for a read command. The minimum supported value is 2.<br/>Recommended values:<br/>DDR2: BL8: 0x6 (not DDR2-1066), 0x7 (DDR2-1066); BL4: 0x4 (not DDR2-1066), 0x5 (DDR2-1066)<br/>DDR3: BL8 - 0x6<br/>DDR4: BL8: 5 + RD_PREAMBLE. RD_PREAMBLE = 1 (1tCK write preamble), 2 (2tCK write preamble)<br/>LPDDR3: BL8: 5 + RU(tDQSCK(max)/tCK) - RD(tDQSCK(min)/tCK) + RU(tODTon(max)/tCK)<br/>Programming Mode: Quasi-dynamic Group 1 and Group 4</p>                                                                                                                                                                                                                                                                                                                                                                             |
| 7          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 6:2        | RW          | 0x00               | <p>rd_odt_delay<br/>The delay, in DFI PHY clock cycles, from issuing a read command to setting ODT values associated with that command. ODT setting must remain constant for the entire time that DQS is driven by the uMCTL2.<br/>Recommended values:<br/>DDR2: CL + AL - 4 (not DDR2-1066), CL + AL - 5 (DDR2-1066). If (CL + AL - 4 &lt; 0), uMCTL2 does not support ODT for read operation.<br/>DDR3: CL - CWL<br/>DDR4: CL - CWL - RD_PREAMBLE + WR_PREAMBLE + DFITMG1.dfi_t_cmd_lat (to adjust for CAL mode). WR_PREAMBLE = 1 (1tCK write preamble), 2 (2tCK write preamble). RD_PREAMBLE = 1 (1tCK write preamble), 2 (2tCK write preamble). If (CL - CWL - RD_PREAMBLE + WR_PREAMBLE) &lt; 0, uMCTL2 does not support ODT for read operation.<br/>LPDDR3: RL + RD(tDQSCK(min)/tCK) - 1 - RU(tODTon(max)/tCK)<br/>Programming Mode: Quasi-dynamic Group 1 and Group 4</p> |
| 1:0        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

**DDRC ODTMAP**

Address: Operational Base + offset (0x0244)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                  |
| 13:12      | RW          | 0x2                | <p>rank1_rd_odt<br/>Indicates which remote ODTs must be turned on during a read from rank 1. Each rank has a remote ODT (in the SDRAM) which can be turned on by setting the appropriate bit here. Rank 0 is controlled by the LSB; rank 1 is controlled by bit next to the LSB, etc. For each rank, set its bit to 1 to enable its ODT.<br/>Programming Mode: Static</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11:10      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                         |
| 9:8        | RW          | 0x2                | rank1_wr_odt<br>Indicates which remote ODTs must be turned on during a write to rank 1. Each rank has a remote ODT (in the SDRAM) which can be turned on by setting the appropriate bit here. Rank 0 is controlled by the LSB; rank 1 is controlled by bit next to the LSB, etc. For each rank, set its bit to 1 to enable its ODT.<br>Programming Mode: Static  |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                         |
| 5:4        | RW          | 0x1                | rank0_rd_odt<br>Indicates which remote ODTs must be turned on during a read from rank 0. Each rank has a remote ODT (in the SDRAM) which can be turned on by setting the appropriate bit here. Rank 0 is controlled by the LSB; rank 1 is controlled by bit next to the LSB, etc. For each rank, set its bit to 1 to enable its ODT.<br>Programming Mode: Static |
| 3:2        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                         |
| 1:0        | RW          | 0x1                | rank0_wr_odt<br>Indicates which remote ODTs must be turned on during a write to rank 0. Each rank has a remote ODT (in the SDRAM) which can be turned on by setting the appropriate bit here. Rank 0 is controlled by the LSB; rank 1 is controlled by bit next to the LSB, etc. For each rank, set its bit to 1 to enable its ODT.<br>Programming Mode: Static  |

**DDRC\_SCHED**

Address: Operational Base + offset (0x0250)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 30:24      | RW          | 0x00               | rdwr_idle_gap<br>When the preferred transaction store is empty for these many clock cycles, switch to the alternate transaction store if it is non-empty. The read transaction store (both high and low priority) is the default preferred transaction store and the write transaction store is the alternative store. When prefer write over read is set this is reversed. 0x0 is a legal value for this register. When set to 0x0, the transaction store switching will happen immediately when the switching conditions become true.<br>Programming Mode: Static |
| 23:12      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11:8       | RW          | 0x8                | <p>lpr_num_entries<br/>Number of entries in the low priority transaction store is this value + 1. (MEMC_NO_OF_ENTRY - (SCHED.lpr_num_entries + 1)) is the number of entries available for the high priority transaction store. Setting this to maximum value allocates all entries to low priority transaction store. Setting this to 0 allocates 1 entry to low priority transaction store and the rest to high priority transaction store.</p> <p>Programming Mode: Static</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 7:3        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 2          | RW          | 0x1                | <p>pageclose<br/>If true, bank is kept open only while there are page hit transactions available in the CAM to that bank. The last read or write command in the CAM with a bank and page hit will be executed with auto-precharge if SCHED1.pageclose_timer=0. Even if this register set to 1 and SCHED1.pageclose_timer is set to 0, explicit precharge (and not auto-precharge) may be issued in some cases where there is a mode switch between Write and Read or between LPR and HPR. The Read and Write commands that are executed as part of the ECC scrub requests are also executed without auto-precharge.<br/>If false, the bank remains open until there is a need to close it (to open a different page, or for page timeout or refresh timeout) - also known as open page policy.<br/>The pageclose feature provides a midway between Open and Close page policies.</p> <p>Programming Mode: Quasi-dynamic Group 3</p> |
| 1:0        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

**DDRC\_SCHED1**

Address: Operational Base + offset (0x0254)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0        | RW          | 0x00               | <p>pageclose_timer</p> <p>This field works in conjunction with SCHED.pageclose. It only has meaning if SCHED.pageclose==1. If SCHED.pageclose==1 and pageclose_timer==0, then an auto-precharge may be scheduled for last read or write command in the CAM with a bank and page hit. Note, sometimes an explicit precharge is scheduled instead of the auto-precharge. See SCHED.pageclose for details of when this may happen. If SCHED.pageclose==1 and pageclose_timer&gt;0, then an auto-precharge is not scheduled for last read or write command in the CAM with a bank and page hit. Instead, a timer is started, with pageclose_timer as the initial value. There is a timer on a per bank basis. The timer decrements unless the next read or write in the CAM to a bank is a page hit. It gets reset to pageclose_timer value if the next read or write in the CAM to a bank is a page hit. Once the timer has reached zero, an explicit precharge will be attempted to be scheduled.</p> <p>Programming Mode: Static</p> |

**DDRC PERFLPR1**

Address: Operational Base + offset (0x0264)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24      | RW          | 0x0f               | <p>lpr_xact_run_length</p> <p>Number of transactions that are serviced once the LPR queue goes critical is the smaller of:</p> <ul style="list-style-type: none"> <li>(a) This number</li> <li>(b) Number of transactions available.</li> </ul> <p>Unit: Transaction.</p> <p>Programming Mode: Quasi-dynamic Group 3</p>                                                                      |
| 23:16      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                      |
| 15:0       | RW          | 0x007f             | <p>lpr_max_starve</p> <p>Number of DFI clocks that the LPR queue can be starved before it goes critical. The minimum valid functional value for this register is 0x1. Programming it to 0x0 will disable the starvation functionality; during normal operation, this function should not be disabled as it will cause excessive latencies.</p> <p>Programming Mode: Quasi-dynamic Group 3</p> |

**DDRC PERFWR1**

Address: Operational Base + offset (0x026c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24      | RW          | 0x0f               | w_xact_run_length<br>Number of transactions that are serviced once the WR queue goes critical is the smaller of:<br>(a) This number<br>(b) Number of transactions available.<br>Unit: Transaction.<br>Programming Mode: Quasi-dynamic Group 3                                                                                                                               |
| 23:16      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                    |
| 15:0       | RW          | 0x007f             | w_max_starve<br>Number of DFI clocks that the WR queue can be starved before it goes critical. The minimum valid functional value for this register is 0x1. Programming it to 0x0 will disable the starvation functionality; during normal operation, this function should not be disabled as it will cause excessive latencies.<br>Programming Mode: Quasi-dynamic Group 3 |

**DDRC DBG0**

Address: Operational Base + offset (0x0300)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 4          | RW          | 0x0                | dis_collision_page_opt<br>When this is set to '0', auto-precharge is disabled for the flushed command in a collision case. Collision cases are write followed by read to same address, read followed by write to same address, or write followed by write to same address with DBG0.dis_wc bit = 1 (where same address comparisons exclude the two address bits representing critical word).<br>Programming Mode: Static |
| 3:0        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                 |

**DDRC DBG1**

Address: Operational Base + offset (0x0304)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2       | RO          | 0x0                | reserved                                                                                                                                                                                                                            |
| 1          | RW          | 0x0                | dis_hif<br>When 1, uMCTL2 asserts the HIF command signal hif_cmd_stall. uMCTL2 will ignore the hif_cmd_valid and all other associated request signals. This bit is intended to be switched on-the-fly.<br>Programming Mode: Dynamic |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0          | RW          | 0x0                | <p>dis_dq</p> <p>When 1, uMCTL2 will not de-queue any transactions from the CAM. Bypass is also disabled. All transactions are queued in the CAM. No reads or writes are issued to SDRAM as long as this is asserted. This bit may be used to prevent reads or writes being issued by the uMCTL2, which makes it safe to modify certain register fields associated with reads and writes (see User Guide for details). After setting this bit, it is strongly recommended to poll DBGCAM.wr_data_pipeline_empty and DBGCAM.rd_data_pipeline_empty, before making changes to any registers which affect reads and writes. This will ensure that the relevant logic in the DDRC is idle. This bit is intended to be switched on-the-fly.</p> <p>Programming Mode: Dynamic</p> |

**DDRC DBGCAM**

Address: Operational Base + offset (0x0308)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 29         | RO          | 0x0                | <p>wr_data_pipeline_empty</p> <p>When 1, indicates that the write data pipeline on the DFI interface is empty. This register is intended to be polled at least twice after setting DBG1.dis_dq, to ensure that all remaining commands/data have completed.</p> <p>Programming Mode: Dynamic</p>                                                                                                                                                                |
| 28         | RO          | 0x0                | <p>rd_data_pipeline_empty</p> <p>When 1, indicates that the read data pipeline on the DFI interface is empty. This register is intended to be polled at least twice after setting DBG1.dis_dq, to ensure that all remaining commands/data have completed.</p> <p>Programming Mode: Dynamic</p>                                                                                                                                                                 |
| 27         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 26         | RO          | 0x0                | <p>dbg_wr_q_empty</p> <p>When 1, all the Write command queues and Write data buffers inside DDRC are empty. This register is to be used for debug purpose. An example use-case scenario: When Controller enters SelfRefresh using the Low-Power entry sequence, Controller is expected to have executed all the commands in its queues and the write and read data drained. Hence this register should be 1 at that time.</p> <p>Programming Mode: Dynamic</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 25         | RO          | 0x0                | dbg_rd_q_empty<br>When 1, all the Read command queues and Read data buffers inside DDRC are empty. This register is to be used for debug purpose. An example use-case scenario: When Controller enters SelfRefresh using the Low-Power entry sequence, Controller is expected to have executed all the commands in its queues and the write and read data drained. Hence this register should be 1 at that time.<br>Programming Mode: Dynamic |
| 24         | RO          | 0x0                | dbg_stall<br>Stall<br>Programming Mode: Dynamic                                                                                                                                                                                                                                                                                                                                                                                               |
| 23:20      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 19:16      | RO          | 0x0                | dbg_w_q_depth<br>Write queue depth<br>The last entry of WR queue is reserved for ECC SCRUB operation. This entry is not included in the calculation of the queue depth.<br>Programming Mode: Dynamic                                                                                                                                                                                                                                          |
| 15:12      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 11:8       | RO          | 0x0                | dbg_lpr_q_depth<br>Low priority read queue depth. The last entry of Lpr queue is reserved for ECC SCRUB operation. This entry is not included in the calculation of the queue depth.<br>Programming Mode: Dynamic                                                                                                                                                                                                                             |
| 7:0        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                      |

**DDRC DBGCMD**

Address: Operational Base + offset (0x030c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                  |
| 5          | RW          | 0x0                | ctrlupd<br>Setting this register bit to 1 indicates to the uMCTL2 to issue a dfi_ctrlupd_req to the PHY. When this request is stored in the uMCTL2, the bit is automatically cleared. This operation must only be performed when DFIUPD0.dis_auto_ctrlupd=1.<br>Programming Mode: Dynamic |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4          | RW          | 0x0                | <p>zq_calib_short</p> <p>Setting this register bit to 1 indicates to the uMCTL2 to issue a ZQCS (ZQ calibration short)/MPC(ZQ calibration) command to the SDRAM. When this request is stored in the uMCTL2, the bit is automatically cleared. This operation can be performed only when ZQCTL0.dis_auto_zq=1. It is recommended NOT to set this register bit if in Init operating mode. This register bit is ignored when in SelfRefresh(except LPDDR4) and SR-Powerdown(LPDDR4) and Deep power-down operating modes and Maximum Power Saving Mode.</p> <p>Programming Mode: Dynamic</p> |
| 3:2        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 1          | RW          | 0x0                | <p>rank1_refresh</p> <p>Setting this register bit to 1 indicates to the uMCTL2 to issue a refresh to rank 1. Writing to this bit causes DBGSTAT.rank1_refresh_busy to be set. When DBGSTAT.rank1_refresh_busy is cleared, the command has been stored in uMCTL2.</p> <p>This operation can be performed only when RFSHCTL3.dis_auto_refresh=1. It is recommended NOT to set this register bit if in Init or Deep power-down operating modes or Maximum Power Saving Mode.</p> <p>Programming Mode: Dynamic</p>                                                                           |
| 0          | RW          | 0x0                | <p>rank0_refresh</p> <p>Setting this register bit to 1 indicates to the uMCTL2 to issue a refresh to rank 0. Writing to this bit causes DBGSTAT.rank0_refresh_busy to be set. When DBGSTAT.rank0_refresh_busy is cleared, the command has been stored in uMCTL2.</p> <p>This operation can be performed only when RFSHCTL3.dis_auto_refresh=1. It is recommended NOT to set this register bit if in Init or Deep power-down operating modes or Maximum Power Saving Mode.</p> <p>Programming Mode: Dynamic</p>                                                                           |

**DDRC DBGSTAT**

Address: Operational Base + offset (0x0310)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5          | RO          | 0x0                | <p>ctrlupd_busy<br/>SoC core may initiate a ctrlupd operation only if this signal is low. This signal goes high in the clock after the uMCTL2 accepts the ctrlupd request. It goes low when the ctrlupd operation is initiated in the uMCTL2. It is recommended not to perform ctrlupd operations when this signal is high.</p> <p>0 - Indicates that the SoC core can initiate a ctrlupd operation<br/>1 - Indicates that ctrlupd operation has not been initiated yet in the uMCTL2</p> <p>Programming Mode: Dynamic</p>                                                         |
| 4          | RO          | 0x0                | <p>zq_calib_short_busy<br/>SoC core may initiate a ZQCS (ZQ calibration short) operation only if this signal is low. This signal goes high in the clock after the uMCTL2 accepts the ZQCS request. It goes low when the ZQCS operation is initiated in the uMCTL2. It is recommended not to perform ZQCS operations when this signal is high.</p> <p>0 - Indicates that the SoC core can initiate a ZQCS operation<br/>1 - Indicates that ZQCS operation has not been initiated yet in the uMCTL2</p> <p>Programming Mode: Dynamic</p>                                             |
| 3:2        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 1          | RO          | 0x0                | <p>rank1_refresh_busy<br/>SoC core may initiate a rank1_refresh operation (refresh operation to rank 1) only if this signal is low. This signal goes high in the clock after DBGCMD.rank1_refresh is set to one. It goes low when the rank1_refresh operation is stored in the uMCTL2. It is recommended not to perform rank1_refresh operations when this signal is high.</p> <p>0 - Indicates that the SoC core can initiate a rank1_refresh operation<br/>1 - Indicates that rank1_refresh operation has not been stored yet in the uMCTL2</p> <p>Programming Mode: Dynamic</p> |
| 0          | RO          | 0x0                | <p>rank0_refresh_busy<br/>SoC core may initiate a rank0_refresh operation (refresh operation to rank 0) only if this signal is low. This signal goes high in the clock after DBGCMD.rank0_refresh is set to one. It goes low when the rank0_refresh operation is stored in the uMCTL2. It is recommended not to perform rank0_refresh operations when this signal is high.</p> <p>0 - Indicates that the SoC core can initiate a rank0_refresh operation<br/>1 - Indicates that rank0_refresh operation has not been stored yet in the uMCTL2</p> <p>Programming Mode: Dynamic</p> |

**DDRC\_SWCTL**

Address: Operational Base + offset (0x0320)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x0                | reserved                                                                                                                                                                                                        |
| 0          | RW          | 0x1                | sw_done<br>Enable quasi-dynamic register programming outside reset.<br>Program register to 0 to enable quasi-dynamic programming. Set back register to 1 once programming is done.<br>Programming Mode: Dynamic |

**DDRC\_SWSTAT**

Address: Operational Base + offset (0x0324)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                   |
| 0          | RO          | 0x1                | sw_done_ack<br>Register programming done. This register is the echo of SWCTL.sw_done. Wait for sw_done value 1 to propagate to sw_done_ack at the end of the programming sequence to ensure that the correct registers values are propagated to the destination clock domains.<br>Programming Mode: Static |

**DDRC\_POISONCFG**

Address: Operational Base + offset (0x036c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                               |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:25      | RO          | 0x0                | reserved                                                                                                                                                                                         |
| 24         | RW          | 0x0                | rd_poison_intr_clr<br>Interrupt clear for read transaction poisoning. Allow 2/3 clock cycles for correct value to propagate to core logic and clear the interrupts.<br>Programming Mode: Dynamic |
| 23:21      | RO          | 0x0                | reserved                                                                                                                                                                                         |
| 20         | RW          | 0x1                | rd_poison_intr_en<br>If set to 1, enables interrupts for read transaction poisoning<br>Programming Mode: Dynamic                                                                                 |
| 19:17      | RO          | 0x0                | reserved                                                                                                                                                                                         |
| 16         | RW          | 0x1                | rd_poison_slverr_en<br>If set to 1, enables SLVERR response for read transaction poisoning<br>Programming Mode: Dynamic                                                                          |
| 15:9       | RO          | 0x0                | reserved                                                                                                                                                                                         |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8          | W1C         | 0x0                | wr_poison_intr_clr<br>Interrupt clear for write transaction poisoning. Allow 2/3 clock cycles for correct value to propagate to core logic and clear the interrupts.<br>Programming Mode: Dynamic |
| 7:5        | RO          | 0x0                | reserved                                                                                                                                                                                          |
| 4          | RW          | 0x1                | wr_poison_intr_en<br>If set to 1, enables interrupts for write transaction poisoning<br>Programming Mode: Dynamic                                                                                 |
| 3:1        | RO          | 0x0                | reserved                                                                                                                                                                                          |
| 0          | RW          | 0x1                | wr_poison_slverr_en<br>If set to 1, enables SLVERR response for write transaction poisoning<br>Programming Mode: Dynamic                                                                          |

**DDRC POISONSTAT**

Address: Operational Base + offset (0x0370)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:17      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 16         | RO          | 0x0                | rd_poison_intr_0<br>Read transaction poisoning error interrupt for port 0. This register is a APB clock copy (double register synchronizer) of the interrupt asserted when a transaction is poisoned on the corresponding AXI port's read address channel. Bit 0 corresponds to Port 0, and so on. Interrupt is cleared by register rd_poison_intr_clr, then value propagated to APB clock.<br>Programming Mode: Dynamic   |
| 15:1       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 0          | RO          | 0x0                | wr_poison_intr_0<br>Write transaction poisoning error interrupt for port 0. This register is a APB clock copy (double register synchronizer) of the interrupt asserted when a transaction is poisoned on the corresponding AXI port's write address channel. Bit 0 corresponds to Port 0, and so on. Interrupt is cleared by register wr_poison_intr_clr, then value propagated to APB clock.<br>Programming Mode: Dynamic |

**DDRC PSTAT**

Address: Operational Base + offset (0x03fc)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                       |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------|
| 31:17      | RO          | 0x0                | reserved                                                                                                 |
| 16         | RO          | 0x0                | wr_port_busy_0<br>Indicates if there are outstanding writes for AXI port 0.<br>Programming Mode: Dynamic |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------|
| 15:1       | RO          | 0x0                | reserved                                                                                                |
| 0          | RO          | 0x0                | rd_port_busy_0<br>Indicates if there are outstanding reads for AXI port 0.<br>Programming Mode: Dynamic |

**DDRC\_PCCFG**

Address: Operational Base + offset (0x0400)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:9       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 8          | RW          | 0x0                | bl_exp_mode<br>Burst length expansion mode. By default (i.e. bl_exp_mode==0) XPI expands every AXI burst into multiple HIF commands, using the memory burst length as a unit. If set to 1, then XPI will use half of the memory burst length as a unit. This applies to both reads and writes. When MSTR.data_bus_width==00, setting bl_exp_mode to 1 has no effect.<br>This can be used in cases where Partial Writes is enabled (UMCTL2_PARTIAL_WR=1), in order to avoid or minimize t_ccd_l penalty in DDR4 and t_ccd_mw penalty in LPDDR4. Hence, bl_exp_mode=1 is only recommended if DDR4 or LPDDR4.<br>Note that if DBICTL.dm_en=0, functionality is not supported in the following cases:<br>UMCTL2_PARTIAL_WR=0<br>UMCTL2_PARTIAL_WR=1, MSTR.data_bus_width=01,<br>MEMC_BURST_LENGTH=8 and<br>MSTR.burst_rdwr=1000 (LPDDR4 only)<br>UMCTL2_PARTIAL_WR=1, MSTR.data_bus_width=01,<br>MEMC_BURST_LENGTH=4 and<br>MSTR.burst_rdwr=0100 (DDR4 only), with either<br>MSTR.burstchop=0 or CRCPARCTL1.crc_enable=1<br>Programming Mode: Static |
| 7:5        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 4          | RW          | 0x0                | pagematch_limit<br>Page match four limit. If set to 1, limits the number of consecutive same page DDRC transactions that can be granted by the Port Arbiter to four when Page Match feature is enabled. If set to 0, there is no limit imposed on number of consecutive same page DDRC transactions.<br>Programming Mode: Static                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 3:1        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0          | RW          | 0x0                | <p>go2critical_en<br/>If set to 1 (enabled), sets co_gs_go2critical_wr and co_gs_go2critical_lpr / co_gs_go2critical_hpr signals going to DDRC based on urgent input (awurgent, arurgent) coming from AXI master. If set to 0 (disabled), co_gs_go2critical_wr and co_gs_go2critical_lpr / co_gs_go2critical_hpr signals at DDRC are driven to 1b'0.</p> <p>Programming Mode: Static</p> |

**DDRC PCFGR\_0**

Address: Operational Base + offset (0x0404)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:15      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 14         | RW          | 0x0                | <p>rd_port_pagematch_en<br/>If set to 1, enables the Page Match feature. If enabled, once a requesting port is granted, the port is continued to be granted if the following immediate commands are to the same memory page (same bank and same row). See also related PCCFG.pagematch_limit register.</p> <p>Programming Mode: Static</p>                                                                                                                                                                                 |
| 13         | RW          | 0x0                | <p>rd_port_urgent_en<br/>If set to 1, enables the AXI urgent sideband signal (arurgent). When enabled and arurgent is asserted by the master, that port becomes the highest priority and co_gs_go2critical_lpr/co_gs_go2critical_hpr signal to DDRC is asserted if enabled in PCCFG.go2critical_en register. Note that arurgent signal can be asserted anytime and as long as required which is independent of address handshaking (it is not associated with any particular command).</p> <p>Programming Mode: Static</p> |
| 12         | RW          | 0x0                | <p>rd_port_aging_en<br/>If set to 1, enables aging function for the read channel of the port.</p> <p>Programming Mode: Static</p>                                                                                                                                                                                                                                                                                                                                                                                          |
| 11:10      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9:0        | RW          | 0x000              | <p>rd_port_priority</p> <p>Determines the initial load value of read aging counters. These counters will be parallel loaded after reset, or after each grant to the corresponding port. The aging counters down-count every clock cycle where the port is requesting but not granted. The higher significant 5-bits of the read aging counter sets the priority of the read channel of a given port. Port's priority will increase as the higher significant 5-bits of the counter starts to decrease. When the aging counter becomes 0, the corresponding port channel will have the highest priority level (timeout condition -Priority0). For single port configurations, the aging counters are only used when they timeout (become 0) to force read-write direction switching. In this case, external dynamic priority input, arqos (for reads only) can still be used to set the DDRC read priority (2 priority levels: low priority read - LPR, high priority read - HPR) on a command by command basis. Note: The two LSBs of this register field are tied internally to 2'b00.</p> <p>Programming Mode: Static</p> |

**DDRC PCFGW\_0**

Address: Operational Base + offset (0x0408)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:15      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 14         | RW          | 0x1                | <p>wr_port_pagematch_en<br/>If set to 1, enables the Page Match feature. If enabled, once a requesting port is granted, the port is continued to be granted if the following immediate commands are to the same memory page (same bank and same row). See also related PCCFG.pagematch_limit register.</p> <p>Programming Mode: Static</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 13         | RW          | 0x0                | <p>wr_port_urgent_en<br/>If set to 1, enables the AXI urgent sideband signal (awurgent). When enabled and awurgent is asserted by the master, that port becomes the highest priority and co_gs_go2critical_wr signal to DDRC is asserted if enabled in PCCFG.go2critical_en register.</p> <p>Note that awurgent signal can be asserted anytime and as long as required which is independent of address handshaking (it is not associated with any particular command).</p> <p>Programming Mode: Static</p>                                                                                                                                                                                                                                                                                                                                                               |
| 12         | RW          | 0x0                | <p>wr_port_aging_en<br/>If set to 1, enables aging function for the write channel of the port.</p> <p>Programming Mode: Static</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 11:10      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 9:0        | RW          | 0x000              | <p>wr_port_priority<br/>Determines the initial load value of write aging counters. These counters will be parallel loaded after reset, or after each grant to the corresponding port. The aging counters down-count every clock cycle where the port is requesting but not granted. The higher significant 5-bits of the write aging counter sets the initial priority of the write channel of a given port. Port's priority will increase as the higher significant 5-bits of the counter starts to decrease. When the aging counter becomes 0, the corresponding port channel will have the highest priority level. For single port configurations, the aging counters are only used when they timeout (become 0) to force read-write direction switching. Note: The two LSBs of this register field are tied internally to 2'b00.</p> <p>Programming Mode: Static</p> |

**DDRC\_PCTRL\_0**

Address: Operational Base + offset (0x0490)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------|
| 31:1       | RO          | 0x0                | reserved                                                                |
| 0          | RW          | 0x0                | <p>port_en<br/>Enables AXI port 0.</p> <p>Programming Mode: Dynamic</p> |

**DDRPHY REG0**

Address: Operational Base + offset (0x0000)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                                 |
| 7:4        | RW          | 0x0                | channel select<br>4'b0011: DQ 16bit<br>4'b1111: DQ 32bit |
| 3          | RW          | 0x1                | soft reset 1, active low                                 |
| 2          | RW          | 0x1                | soft reset 0, active low                                 |
| 1          | RW          | 0x1                |                                                          |
| 0          | RW          | 0x1                |                                                          |

**DDRPHY REG1**

Address: Operational Base + offset (0x0004)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                             |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x0                | reserved                                                                                                                                       |
| 4          | RW          | 0x0                | Read ODT bypass mode enable signal, High active.<br>Releated register REG03 and REG04                                                          |
| 3          | RW          | 0x1                | PHY burst type select:<br>1: burst8                                                                                                            |
| 2:0        | RW          | 0x0                | PHY working condition select<br>0x0: ddr2 PHY mode<br>0x1: lpddr2 PHY mode<br>0x2: ddr3 PHY mode<br>0x3: lpddr3 PHY mode<br>0x4: ddr4 PHY mode |

**DDRPHY REG2**

Address: Operational Base + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                                                                                       |
| 7:6        | RW          | 0x0                | Write leveling CS select signal<br>2'b00: select CS0 and CS1<br>2'b01: select CS1<br>2'b10: select CS0         |
| 5:4        | RW          | 0x0                | DQS gating calibration CS select signal<br>2'b00: select CS0 and CS1<br>2'b01: select CS1<br>2'b10: select CS0 |
| 3          | RW          | 0x0                | Write leveling calibration bypass mode, active high                                                            |
| 2          | RW          | 0x0                | Write leveling calibration control, active high                                                                |
| 1          | RW          | 0x0                | DQS gating calibration bypass mode, active high                                                                |
| 0          | RW          | 0x0                | DQS gating calibration control, active high                                                                    |

**DDRPHY\_REG3**

Address: Operational Base + offset (0x000c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                               |
|------------|-------------|--------------------|------------------------------------------------------------------|
| 31:7       | RO          | 0x0                | reserved                                                         |
| 6:4        | RW          | 0x2                | right channel A read ODT delay by read odt configure bypass mode |
| 3          | RO          | 0x0                | reserved                                                         |
| 2:0        | RW          | 0x2                | left channel A read ODT delay by read odt configure bypass mode  |

**DDRPHY\_REG4**

Address: Operational Base + offset (0x0010)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                               |
|------------|-------------|--------------------|------------------------------------------------------------------|
| 31:7       | RO          | 0x0                | reserved                                                         |
| 6:4        | RW          | 0x2                | right channel B read ODT delay by read odt configure bypass mode |
| 3          | RO          | 0x0                | reserved                                                         |
| 2:0        | RW          | 0x2                | left channel B read ODT delay by read odt configure bypass mode  |

**DDRPHY\_REG5**

Address: Operational Base + offset (0x0014)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>            |
|------------|-------------|--------------------|-------------------------------|
| 31:8       | RO          | 0x0                | reserved                      |
| 7:0        | RW          | 0x00               | Write leveling load mode[7:0] |

**DDRPHY\_REG6**

Address: Operational Base + offset (0x0018)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:8       | RO          | 0x0                | reserved                             |
| 7:6        | RW          | 0x0                | Write leveling load mode select[1:0] |
| 5:0        | RW          | 0x02               | Write leveling load mode[13:8]       |

**DDRPHY\_REG9**

Address: Operational Base + offset (0x0024)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>        |
|------------|-------------|--------------------|---------------------------|
| 31:7       | RO          | 0x0                | reserved                  |
| 6          | RW          | 0x0                | 0: Normal mode; 1: Bypass |
| 5:0        | RO          | 0x0                | reserved                  |

**DDRPHY\_REGA**

Address: Operational Base + offset (0x0028)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                             |
|------------|-------------|--------------------|------------------------------------------------|
| 31:6       | RO          | 0x0                | reserved                                       |
| 5:0        | RW          | 0x00               | DDR2 /DDR3/DDR4 CAS Latency; LPDDR2/3 RL value |

**DDRPHY REGB**

Address: Operational Base + offset (0x002c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>              |
|------------|-------------|--------------------|---------------------------------|
| 31:5       | RO          | 0x0                | reserved                        |
| 4:0        | RW          | 0x00               | DDR2/DDR3/DDR4 additive latency |

**DDRPHY REGC**

Address: Operational Base + offset (0x0030)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                  |
|------------|-------------|--------------------|-----------------------------------------------------|
| 31:5       | RO          | 0x0                | reserved                                            |
| 4:0        | RW          | 0x00               | DDR2/DDR3/DDR4 WRITE CAS Latency; LPDDR2/3 WL value |

**DDRPHY REG11**

Address: Operational Base + offset (0x0044)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x0                | reserved                                                                             |
| 4:0        | RW          | 0x14               | CMD NRCOMP, except for CK/CKB. The larger the value, the stronger the drive strength |

**DDRPHY REG12**

Address: Operational Base + offset (0x0048)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                                                              |
| 7:3        | RW          | 0x14               | CMD PRCOMP, except for CK/CKB. The larger the value, the stronger the driver strength |
| 2          | RO          | 0x0                | reserved                                                                              |
| 1          | RW          | 0x1                | CMD weak pull up enable, active low                                                   |
| 0          | RW          | 0x0                | CMD weak pull down enable, active high                                                |

**DDRPHY REG13**

Address: Operational Base + offset (0x004c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x0                | reserved                                                                                                                                                             |
| 4          | RW          | 0x0                | CMD DLL clock phase select in bypass mode<br>0: no delay      1: 90°delay                                                                                            |
| 3          | RW          | 0x1                | CMD DLL enable<br>0: disable      1: enable                                                                                                                          |
| 2:0        | RW          | 0x4                | CMD AND ADDRESS DLL delay<br>0: no delay      1: 22.5°delay<br>2: 45°delay      3: 67.5°delay<br>4: 90°delay      5: 112.5°delay<br>6: 135°delay      7: 157.5°delay |

**DDRPHY REG14**

Address: Operational Base + offset (0x0050)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4       | RO          | 0x0                | reserved                                                                                                                                                |
| 3          | RW          | 0x1                | CK DLL clock phase select in bypass mode<br>0: no delay      1: 90°delay                                                                                |
| 2:0        | RW          | 0x0                | CK DLL delay<br>0: no delay      1: 22.5°delay<br>2: 45°delay      3: 67.5°delay<br>4: 90°delay      5: 112.5°delay<br>6: 135°delay      7: 157.5°delay |

**DDRPHY REG15**

Address: Operational Base + offset (0x0054)

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

**DDRPHY REG16**

Address: Operational Base + offset (0x0058)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------|
| 31:5       | RO          | 0x0                | reserved                                                             |
| 4:0        | RW          | 0x14               | CK/CKB NRCOMP. The larger the value, the stronger the drive strength |

**DDRPHY REG17**

Address: Operational Base + offset (0x005c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------|
| 31:7       | RO          | 0x0                | reserved                                                                           |
| 6:4        | RW          | 0x4                | CMD/CK falling edge slew rate control, larger value means larger falling slew rate |
| 3          | RO          | 0x0                | reserved                                                                           |
| 2:0        | RW          | 0x4                | CMD/CK rising edge slew rate control, larger vale means larger rising slew rate    |

**DDRPHY REG18**

Address: Operational Base + offset (0x0060)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------|
| 31:5       | RO          | 0x0                | reserved                                                             |
| 4:0        | RW          | 0x14               | CK/CKB PRCOMP. The larger the value, the stronger the drive strength |

**DDRPHY REG1B**

Address: Operational Base + offset (0x006c)

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

**DDRPHY REG1F**

Address: Operational Base + offset (0x007c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                                                |
| 7:4        | RW          | 0x3                | The response timing when detect the dfi_lp_req is high. Unit: dfi_clk1x |
| 3:0        | RW          | 0x0                | The response timing when high the dfi_lp_ack. Unit: dfi_clk1x           |

**DDRPHY REG20**

Address: Operational Base + offset (0x0080)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x0                | reserved                                                                                                      |
| 4:0        | RW          | 0x14               | Left channel A NRCOMP. The larger the value, the stronger the drive strength in the scope from A_DQ0 to A_DQ7 |

**DDRPHY REG21**

Address: Operational Base + offset (0x0084)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x0                | reserved                                                                                                                   |
| 4:0        | RW          | 0x04               | Left channel A read pull-up ODT. The larger the value, the smaller the pull-up resistance in the scope from A_DQ0 to A_DQ7 |

**DDRPHY REG22**

Address: Operational Base + offset (0x0088)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 31:2       | RO          | 0x0                | reserved                                             |
| 1          | RW          | 0x1                | Left channel A DQ weak pull up enable, active low    |
| 0          | RW          | 0x0                | Left channel A DQ weak pull down enable, active high |

**DDRPHY REG26**

Address: Operational Base + offset (0x0098)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x0                | reserved                                                                                 |
| 4          | RW          | 0x0                | Left channel A write DQ DLL phase select in bypass mode.<br>0: no delay      1: 90°delay |
| 3          | RW          | 0x1                | Left channel A write DQ DLL enable, active HIGH                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                       |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:0        | RW          | 0x4                | Left channel A write DQ DLL delay<br>0: no delay 1: 22.5°delay<br>2: 45°delay 3: 67.5°delay<br>4: 90°delay 5: 112.5°delay<br>6: 135°delay 7: 157.5°delay |

**DDRPHY\_REG27**

Address: Operational Base + offset (0x009c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                        |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4       | RO          | 0x0                | reserved                                                                                                                                                  |
| 3          | RW          | 0x0                | Left channel A write DQS DLL phase select in bypass mode.<br>0: no delay 1: 90°delay                                                                      |
| 2:0        | RW          | 0x0                | Left channel A write DQS DLL delay<br>0: no delay 1: 22.5°delay<br>2: 45°delay 3: 67.5°delay<br>4: 90°delay 5: 112.5°delay<br>6: 135°delay 7: 157.5°delay |

**DDRPHY\_REG28**

Address: Operational Base + offset (0x00a0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------|
| 31:2       | RO          | 0x0                | reserved                                                                                    |
| 1:0        | RW          | 0x1                | Left channel A read DQS DLL delay<br>0: no delay 1: 22.5°delay<br>2: 45°delay 3: 67.5°delay |

**DDRPHY\_REG29**

Address: Operational Base + offset (0x00a4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                        |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2       | RO          | 0x0                | reserved                                                                                                                                                  |
| 1          | RW          | 0x1                | Weak pull up of the A_DQS[0]                                                                                                                              |
| 0          | RW          | 0x0                | Weak pull down of the A_DQS[0].<br>REG29[1:0]=2'b00. Pull Up<br>REG29[1:0]=2'b01. Middle Level<br>REG29[1:0]=2'b10. High-Z<br>REG29[1:0]=2'b11. Pull Down |

**DDRPHY\_REG2B**

Address: Operational Base + offset (0x00ac)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                                                                   |
| 7:5        | RW          | 0x4                | Left channel A falling edge slew rate control, larger value means larger falling slew rate |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------|
| 4:2        | RW          | 0x0                | Left channel A rising edge slew rate control, larger value means larger rising slew rate |
| 1:0        | RW          | 0x1                |                                                                                          |

**DDRPHY\_REG2C**

Address: Operational Base + offset (0x00b0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                                                                                              |
| 7:5        | RW          | 0x0                | Write the cyclesel configure low 8bit of A channel when in calibartion bypass mode for CS0. Related register REG02[1] |
| 4:3        | RW          | 0x0                | Write the ophsel configure low 8bit of A channel when in calibartion bypass mode for CS0. Related register REG02[1]   |
| 2:0        | RW          | 0x0                | Write the dll configure low 8bit of A channel when in calibartion bypass mode for CS0. Related register REG02[1]      |

**DDRPHY\_REG2D**

Address: Operational Base + offset (0x00b4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                                                                                              |
| 7:5        | RW          | 0x0                | Write the cyclesel configure low 8bit of A channel when in calibartion bypass mode for CS1. Related register REG02[1] |
| 4:3        | RW          | 0x0                | Write the ophsel configure low 8bit of A channel when in calibartion bypass mode for CS1. Related register REG02[1]   |
| 2:0        | RW          | 0x0                | Write the dll configure low 8bit of A channel when in calibartion bypass mode for CS1. Related register REG02[1]      |

**DDRPHY\_REG2E**

Address: Operational Base + offset (0x00b8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x0                | reserved                                                                                                                   |
| 4:0        | RW          | 0x04               | Left channel A read pull-up ODT. The larger the value, the smaller the pull-up resistance in the scope from A_DQ0 to A_DQ7 |

**DDRPHY\_REG2F**

Address: Operational Base + offset (0x00bc)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x0                | reserved                                                                                                      |
| 4:0        | RW          | 0x14               | Left channel A PRCOMP. The larger the value, the stronger the drive strength in the scope from A_DQ0 to A_DQ7 |

**DDRPHY\_REG30**

Address: Operational Base + offset (0x00c0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x0                | reserved                                                                                                        |
| 4:0        | RW          | 0x14               | Right channel A NRCOMP. The larger the value, the stronger the drive strength in the scope from A_DQ8 to A_DQ15 |

**DDRPHY REG31**

Address: Operational Base + offset (0x00c4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x0                | reserved                                                                                                                         |
| 4:0        | RW          | 0x04               | Right channel A read pull-down ODT. The larger the value, the smaller the pull-down resistance in the scope from A_DQ8 to A_DQ15 |

**DDRPHY REG32**

Address: Operational Base + offset (0x00c8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                    |
|------------|-------------|--------------------|-------------------------------------------------------|
| 31:2       | RO          | 0x0                | reserved                                              |
| 1          | RW          | 0x1                | Right channel A DQ weak pull up enable, active low    |
| 0          | RW          | 0x0                | Right channel A DQ weak pull down enable, active high |

**DDRPHY REG36**

Address: Operational Base + offset (0x00d8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                        |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x0                | reserved                                                                                                                                                  |
| 4          | RW          | 0x0                | Right channel A write DQ DLL phase select in bypass mode<br>0: no delay 1: 90°delay                                                                       |
| 3          | RW          | 0x0                | Right channel A write DQ DLL enable, active high                                                                                                          |
| 2:0        | RW          | 0x4                | Right channel A write DQ DLL delay<br>0: no delay 1: 22.5°delay<br>2: 45°delay 3: 67.5°delay<br>4: 90°delay 5: 112.5°delay<br>6: 135°delay 7: 157.5°delay |

**DDRPHY REG37**

Address: Operational Base + offset (0x00dc)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4       | RO          | 0x0                | reserved                                                                                                                                                   |
| 3          | RW          | 0x0                | Right channel A write DQS DLL phase select in bypass mode.<br>0: no delay 1: 90°delay                                                                      |
| 2:0        | RW          | 0x0                | Right channel A write DQS DLL delay<br>0: no delay 1: 22.5°delay<br>2: 45°delay 3: 67.5°delay<br>4: 90°delay 5: 112.5°delay<br>6: 135°delay 7: 157.5°delay |

**DDRPHY REG38**

Address: Operational Base + offset (0x00e0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------|
| 31:2       | RO          | 0x0                | reserved                                                                                     |
| 1:0        | RW          | 0x1                | Right channel A read DQS DLL delay<br>0: no delay 1: 22.5°delay<br>2: 45°delay 3: 67.5°delay |

**DDRPHY REG39**

Address: Operational Base + offset (0x00e4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2       | RO          | 0x0                | reserved                                                                                                                                                             |
| 1          | RW          | 0x1                | Weak pull up of the A_DQS[1]                                                                                                                                         |
| 0          | RW          | 0x0                | Weak pull down of the A_DQS[1].<br>REG39[1:0] = 2'b00. Pull Up.<br>REG39[1:0] = 2'b01. Middle level.<br>REG39[1:0] = 2'b10. High-Z.<br>REG39[1:0] = 2'b11. Pull Down |

**DDRPHY REG3A**

Address: Operational Base + offset (0x00e8)

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

**DDRPHY REG3B**

Address: Operational Base + offset (0x00ec)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                                                                    |
| 7:5        | RW          | 0x4                | Right channel A falling edge slew rate control, larger value means larger falling slew rate |
| 4:2        | RW          | 0x0                | Right channel A rising edge slew rate control, larger value means larger rising slew rate   |
| 1:0        | RW          | 0x1                |                                                                                             |

**DDRPHY REG3C**

Address: Operational Base + offset (0x00f0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                                                                                               |
| 7:5        | RW          | 0x0                | Write the cyclesel configure high 8bit of A channel when in calibration bypass mode for CS0. Related register REG02[1] |
| 4:3        | RW          | 0x0                | Write the ophsel configure high 8bit of A channel when in calibration bypass mode for CS0. Related register REG02[1]   |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------|
| 2:0        | RW          | 0x0                | Write the dll configure high 8bit of A channel when in calibration bypass mode for CS0. Related register REG02[1] |

**DDRPHY REG3D**

Address: Operational Base + offset (0x00f4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                                                                                               |
| 7:5        | RW          | 0x0                | Write the cyclesel configure high 8bit of A channel when in calibration bypass mode for CS1. Related register REG02[1] |
| 4:3        | RW          | 0x0                | Write the ophsel configure high 8bit of A channel when in calibration bypass mode for CS1. Related register REG02[1]   |
| 2:0        | RW          | 0x0                | Write the dll configure high 8bit of A channel when in calibration bypass mode for CS1. Related register REG02[1]      |

**DDRPHY REG3E**

Address: Operational Base + offset (0x00f8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                           |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x0                | reserved                                                                                                                     |
| 4:0        | RW          | 0x04               | Right channel A read pull-up ODT. The larger the value, the smaller the pull-up resistance in the scope from A_DQ8 to A_DQ15 |

**DDRPHY REG3F**

Address: Operational Base + offset (0x00fc)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x0                | reserved                                                                                                        |
| 4:0        | RW          | 0x14               | Right channel A PRCOMP. The larger the value, the stronger the drive strength in the scope from A_DQ8 to A_DQ15 |

**DDRPHY REG40**

Address: Operational Base + offset (0x0100)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x0                | reserved                                                                                                      |
| 4:0        | RW          | 0x14               | Left channel B NRCOMP. The larger the value, the stronger the drive strength in the scope from B_DQ0 to B_DQ7 |

**DDRPHY REG41**

Address: Operational Base + offset (0x0104)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                             |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x0                | reserved                                                                                                                       |
| 4:0        | RW          | 0x04               | Left channel B read pull-down ODT. The larger the value, the smaller the pull-down resistance in the scope from B_DQ0 to B_DQ7 |

**DDRPHY\_REG42**

Address: Operational Base + offset (0x0108)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 31:2       | RO          | 0x0                | reserved                                             |
| 1          | RW          | 0x0                | Left channel B DQ weak pull up enable, active low    |
| 0          | RW          | 0x0                | Left channel B DQ weak pull down enable, active high |

**DDRPHY\_REG46**

Address: Operational Base + offset (0x0118)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                       |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x0                | reserved                                                                                                                                                 |
| 4          | RW          | 0x0                | Left channel B write DQ DLL phase select in bypass mode.<br>0: no delay 1: 90°delay                                                                      |
| 3          | RW          | 0x1                | Left channel B write DQ DLL enable, active HIGH                                                                                                          |
| 2:0        | RW          | 0x4                | Left channel B write DQ DLL delay<br>0: no delay 1: 22.5°delay<br>2: 45°delay 3: 67.5°delay<br>4: 90°delay 5: 112.5°delay<br>6: 135°delay 7: 157.5°delay |

**DDRPHY\_REG47**

Address: Operational Base + offset (0x011c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                        |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4       | RO          | 0x0                | reserved                                                                                                                                                  |
| 3          | RW          | 0x0                | Left channel B write DQS DLL phase select in bypass mode.<br>0: no delay 1: 90°delay                                                                      |
| 2:0        | RW          | 0x0                | Left channel B write DQS DLL delay<br>0: no delay 1: 22.5°delay<br>2: 45°delay 3: 67.5°delay<br>4: 90°delay 5: 112.5°delay<br>6: 135°delay 7: 157.5°delay |

**DDRPHY\_REG48**

Address: Operational Base + offset (0x0120)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------|
| 31:2       | RO          | 0x0                | reserved                                                                                    |
| 1:0        | RW          | 0x1                | Left channel B read DQS DLL delay<br>0: no delay 1: 22.5°delay<br>2: 45°delay 3: 67.5°delay |

**DDRPHY\_REG49**

Address: Operational Base + offset (0x0124)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2       | RO          | 0x0                | reserved                                                                                                                                                             |
| 1          | RW          | 0x1                | Weak pull up of the B_DQS[0]                                                                                                                                         |
| 0          | RW          | 0x0                | Weak pull down of the B_DQS[0].<br>REG49[1:0] = 2'b00. Pull Up.<br>REG49[1:0] = 2'b01. Middle level.<br>REG49[1:0] = 2'b10. High-Z.<br>REG49[1:0] = 2'b11. Pull Down |

**DDRPHY REG4A**

Address: Operational Base + offset (0x0128)

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

**DDRPHY REG4B**

Address: Operational Base + offset (0x012c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                                                                   |
| 7:5        | RW          | 0x4                | Left channel B falling edge slew rate control, larger value means larger falling slew rate |
| 4:2        | RW          | 0x4                | Left channel B rising edge slew rate control, larger value means larger rising slew rate   |
| 1:0        | RW          | 0x1                |                                                                                            |

**DDRPHY REG4C**

Address: Operational Base + offset (0x0130)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                                                                                              |
| 7:5        | RW          | 0x0                | Write the cyclesel configure low 8bit of B channel when in calibration bypass mode for CS0. Related register REG02[1] |
| 4:3        | RW          | 0x0                | Write the ophsel configure low 8bit of B channel when in calibration bypass mode for CS0. Related register REG02[1]   |
| 2:0        | RW          | 0x0                | Write the dll configure low 8bit of B channel when in calibration bypass mode for CS0. Related register REG02[1]      |

**DDRPHY REG4D**

Address: Operational Base + offset (0x0134)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                                                                                              |
| 7:5        | RW          | 0x0                | Write the cyclesel configure low 8bit of B channel when in calibration bypass mode for CS1. Related register REG02[1] |
| 4:3        | RW          | 0x0                | Write the ophsel configure low 8bit of B channel when in calibration bypass mode for CS1. Related register REG02[1]   |
| 2:0        | RW          | 0x0                | Write the dll configure low 8bit of B channel when in calibration bypass mode for CS1. Related register REG02[1]      |

**DDRPHY\_REG4E**

Address: Operational Base + offset (0x0138)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x0                | reserved                                                                                                                   |
| 4:0        | RW          | 0x04               | Left channel B read pull-up ODT. The larger the value, the smaller the pull-up resistance in the scope from B_DQ0 to B_DQ7 |

**DDRPHY\_REG4F**

Address: Operational Base + offset (0x013c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x0                | reserved                                                                                                      |
| 4:0        | RW          | 0x14               | Left channel B PRCOMP. The larger the value, the stronger the drive strength in the scope from B_DQ0 to B_DQ7 |

**DDRPHY\_REG50**

Address: Operational Base + offset (0x0140)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x0                | reserved                                                                                                        |
| 4:0        | RW          | 0x14               | Right channel B NRCOMP. The larger the value, the stronger the drive strength in the scope from B_DQ8 to B_DQ15 |

**DDRPHY\_REG51**

Address: Operational Base + offset (0x0144)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x0                | reserved                                                                                                                         |
| 4:0        | RW          | 0x04               | Right channel B read pull-down ODT. The larger the value, the smaller the pull-down resistance in the scope from B_DQ8 to B_DQ15 |

**DDRPHY\_REG52**

Address: Operational Base + offset (0x0148)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                    |
|------------|-------------|--------------------|-------------------------------------------------------|
| 31:2       | RO          | 0x0                | reserved                                              |
| 1          | RW          | 0x1                | Right channel B DQ weak pull up enable, active low    |
| 0          | RW          | 0x0                | Right channel B DQ weak pull down enable, active high |

**DDRPHY REG56**

Address: Operational Base + offset (0x0158)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                        |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x0                | reserved                                                                                                                                                  |
| 4          | RW          | 0x0                | Right channel B write DQ DLL phase select in bypass mode.<br>0: no delay 1: 90°delay                                                                      |
| 3          | RW          | 0x1                | Right channel B write DQ DLL enable, active HIGH                                                                                                          |
| 2:0        | RW          | 0x4                | Right channel B write DQ DLL delay<br>0: no delay 1: 22.5°delay<br>2: 45°delay 3: 67.5°delay<br>4: 90°delay 5: 112.5°delay<br>6: 135°delay 7: 157.5°delay |

**DDRPHY REG57**

Address: Operational Base + offset (0x015c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4       | RO          | 0x0                | reserved                                                                                                                                                   |
| 3          | RW          | 0x0                | Right channel B write DQS DLL phase select in bypass mode.<br>0: no delay 1: 90°delay                                                                      |
| 2:0        | RW          | 0x0                | Right channel B write DQS DLL delay<br>0: no delay 1: 22.5°delay<br>2: 45°delay 3: 67.5°delay<br>4: 90°delay 5: 112.5°delay<br>6: 135°delay 7: 157.5°delay |

**DDRPHY REG58**

Address: Operational Base + offset (0x0160)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------|
| 31:2       | RO          | 0x0                | reserved                                                                                     |
| 1:0        | RW          | 0x1                | Right channel B read DQS DLL delay<br>0: no delay 1: 22.5°delay<br>2: 45°delay 3: 67.5°delay |

**DDRPHY REG59**

Address: Operational Base + offset (0x0164)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2       | RO          | 0x0                | reserved                                                                                                                                                             |
| 1          | RW          | 0x1                | Weak pull up of the B_DQS[1]                                                                                                                                         |
| 0          | RW          | 0x0                | Weak pull down of the B_DQS[1].<br>REG59[1:0] = 2'b00. Pull Up.<br>REG59[1:0] = 2'b01. Middle level.<br>REG59[1:0] = 2'b10. High-Z.<br>REG59[1:0] = 2'b11. Pull Down |

**DDRPHY REG5A**

Address: Operational Base + offset (0x0168)

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:8 | RO   | 0x0         | reserved    |
| 7:0  | RW   | 0x01        |             |

**DDRPHY REG5B**

Address: Operational Base + offset (0x016c)

| Bit  | Attr | Reset Value | Description                                                                                 |
|------|------|-------------|---------------------------------------------------------------------------------------------|
| 31:8 | RO   | 0x0         | reserved                                                                                    |
| 7:5  | RW   | 0x4         | Right channel B falling edge slew rate control, larger value means larger falling slew rate |
| 4:2  | RW   | 0x4         | Right channel B rising edge slew rate control, larger value means larger rising slew rate   |
| 1:0  | RW   | 0x1         |                                                                                             |

**DDRPHY REG5C**

Address: Operational Base + offset (0x0170)

| Bit  | Attr | Reset Value | Description                                                                                                            |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------|
| 31:8 | RO   | 0x0         | reserved                                                                                                               |
| 7:5  | RW   | 0x0         | Write the cyclesel configure high 8bit of B channel when in calibration bypass mode for CS0. Related register REG02[1] |
| 4:3  | RW   | 0x0         | Write the ophsel configure high 8bit of B channel when in calibration bypass mode for CS0. Related register REG02[1]   |
| 2:0  | RW   | 0x0         | Write the dll configure high 8bit of B channel when in calibration bypass mode for CS0. Related register REG02[1]      |

**DDRPHY REG5D**

Address: Operational Base + offset (0x0174)

| Bit  | Attr | Reset Value | Description                                                                                                            |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------|
| 31:8 | RO   | 0x0         | reserved                                                                                                               |
| 7:5  | RW   | 0x0         | Write the cyclesel configure high 8bit of B channel when in calibration bypass mode for CS1. Related register REG02[1] |
| 4:3  | RW   | 0x0         | Write the ophsel configure high 8bit of B channel when in calibration bypass mode for CS1. Related register REG02[1]   |
| 2:0  | RW   | 0x0         | Write the dll configure high 8bit of B channel when in calibration bypass mode for CS1. Related register REG02[1]      |

**DDRPHY REG5E**

Address: Operational Base + offset (0x0178)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                           |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x0                | reserved                                                                                                                     |
| 4:0        | RW          | 0x04               | Right channel B read pull-up ODT. The larger the value, the smaller the pull-up resistance in the scope from B_DQ8 to B_DQ15 |

**DDRPHY REG5F**

Address: Operational Base + offset (0x017c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x0                | reserved                                                                                                        |
| 4:0        | RW          | 0x14               | Right channel B PRCOMP. The larger the value, the stronger the drive strength in the scope from B_DQ8 to B_DQ15 |

**DDRPHY REG70**

Address: Operational Base + offset (0x01c0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>   |
|------------|-------------|--------------------|----------------------|
| 31:8       | RO          | 0x0                | reserved             |
| 7:4        | RW          | 0x7                | CS0 A_DM0 RX de-skew |
| 3:0        | RW          | 0x7                | CS0 A_DM0 TX de-skew |

**DDRPHY REG71**

Address: Operational Base + offset (0x01c4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>   |
|------------|-------------|--------------------|----------------------|
| 31:8       | RO          | 0x0                | reserved             |
| 7:4        | RW          | 0x7                | CS0 A_DQ0 RX de-skew |
| 3:0        | RW          | 0x7                | CS0 A_DQ0 TX de-skew |

**DDRPHY REG72**

Address: Operational Base + offset (0x01c8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>   |
|------------|-------------|--------------------|----------------------|
| 31:8       | RO          | 0x0                | reserved             |
| 7:4        | RW          | 0x7                | CS0 A_DQ1 RX de-skew |
| 3:0        | RW          | 0x7                | CS0 A_DQ1 TX de-skew |

**DDRPHY REG73**

Address: Operational Base + offset (0x01cc)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>   |
|------------|-------------|--------------------|----------------------|
| 31:8       | RO          | 0x0                | reserved             |
| 7:4        | RW          | 0x7                | CS0 A_DQ2 RX de-skew |
| 3:0        | RW          | 0x7                | CS0 A_DQ2 TX de-skew |

**DDRPHY REG74**

Address: Operational Base + offset (0x01d0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>   |
|------------|-------------|--------------------|----------------------|
| 31:8       | RO          | 0x0                | reserved             |
| 7:4        | RW          | 0x7                | CS0 A_DQ3 RX de-skew |
| 3:0        | RW          | 0x7                | CS0 A_DQ3 TX de-skew |

**DDRPHY REG75**

Address: Operational Base + offset (0x01d4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>   |
|------------|-------------|--------------------|----------------------|
| 31:8       | RO          | 0x0                | reserved             |
| 7:4        | RW          | 0x7                | CS0 A_DQ4 RX de-skew |
| 3:0        | RW          | 0x7                | CS0 A_DQ4 TX de-skew |

**DDRPHY REG76**

Address: Operational Base + offset (0x01d8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>   |
|------------|-------------|--------------------|----------------------|
| 31:8       | RO          | 0x0                | reserved             |
| 7:4        | RW          | 0x7                | CS0 A_DQ5 RX de-skew |
| 3:0        | RW          | 0x7                | CS0 A_DQ5 TX de-skew |

**DDRPHY REG77**

Address: Operational Base + offset (0x01dc)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>   |
|------------|-------------|--------------------|----------------------|
| 31:8       | RO          | 0x0                | reserved             |
| 7:4        | RW          | 0x7                | CS0 A_DQ6 RX de-skew |
| 3:0        | RW          | 0x7                | CS0 A_DQ6 TX de-skew |

**DDRPHY REG78**

Address: Operational Base + offset (0x01e0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>   |
|------------|-------------|--------------------|----------------------|
| 31:8       | RO          | 0x0                | reserved             |
| 7:4        | RW          | 0x7                | CS0 A_DQ7 RX de-skew |
| 3:0        | RW          | 0x7                | CS0 A_DQ7 TX de-skew |

**DDRPHY REG79**

Address: Operational Base + offset (0x01e4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>    |
|------------|-------------|--------------------|-----------------------|
| 31:8       | RO          | 0x0                | reserved              |
| 7:4        | RW          | 0x7                | CS0 A_DQS0 RX de-skew |
| 3:0        | RW          | 0x7                | CS0 A_DQS0 TX de-skew |

**DDRPHY REG7A**

Address: Operational Base + offset (0x01e8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>     |
|------------|-------------|--------------------|------------------------|
| 31:4       | RO          | 0x0                | reserved               |
| 3:0        | RW          | 0x7                | CS0 A_DQSB0 TX de-skew |

**DDRPHY\_REG7B**

Address: Operational Base + offset (0x01ec)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>   |
|------------|-------------|--------------------|----------------------|
| 31:8       | RO          | 0x0                | reserved             |
| 7:4        | RW          | 0x7                | CS0 A_DM1 RX de-skew |
| 3:0        | RW          | 0x7                | CS0 A_DM1 TX de-skew |

**DDRPHY\_REG7C**

Address: Operational Base + offset (0x01f0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>   |
|------------|-------------|--------------------|----------------------|
| 31:8       | RO          | 0x0                | reserved             |
| 7:4        | RW          | 0x7                | CS0 A_DQ8 RX de-skew |
| 3:0        | RW          | 0x7                | CS0 A_DQ8 TX de-skew |

**DDRPHY\_REG7D**

Address: Operational Base + offset (0x01f4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>   |
|------------|-------------|--------------------|----------------------|
| 31:8       | RO          | 0x0                | reserved             |
| 7:4        | RW          | 0x7                | CS0 A_DQ9 RX de-skew |
| 3:0        | RW          | 0x7                | CS0 A_DQ9 TX de-skew |

**DDRPHY\_REG7E**

Address: Operational Base + offset (0x01f8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>    |
|------------|-------------|--------------------|-----------------------|
| 31:8       | RO          | 0x0                | reserved              |
| 7:4        | RW          | 0x7                | CS0 A_DQ10 RX de-skew |
| 3:0        | RW          | 0x7                | CS0 A_DQ10 TX de-skew |

**DDRPHY\_REG7F**

Address: Operational Base + offset (0x01fc)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>    |
|------------|-------------|--------------------|-----------------------|
| 31:8       | RO          | 0x0                | reserved              |
| 7:4        | RW          | 0x7                | CS0 A_DQ11 RX de-skew |
| 3:0        | RW          | 0x7                | CS0 A_DQ11 TX de-skew |

**DDRPHY\_REG80**

Address: Operational Base + offset (0x0200)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>    |
|------------|-------------|--------------------|-----------------------|
| 31:8       | RO          | 0x0                | reserved              |
| 7:4        | RW          | 0x7                | CS0 A_DQ12 RX de-skew |
| 3:0        | RW          | 0x7                | CS0 A_DQ12 TX de-skew |

**DDRPHY REG81**

Address: Operational Base + offset (0x0204)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>    |
|------------|-------------|--------------------|-----------------------|
| 31:8       | RO          | 0x0                | reserved              |
| 7:4        | RW          | 0x7                | CS0 A_DQ13 RX de-skew |
| 3:0        | RW          | 0x7                | CS0 A_DQ13 TX de-skew |

**DDRPHY REG82**

Address: Operational Base + offset (0x0208)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>    |
|------------|-------------|--------------------|-----------------------|
| 31:8       | RO          | 0x0                | reserved              |
| 7:4        | RW          | 0x7                | CS0 A_DQ14 RX de-skew |
| 3:0        | RW          | 0x7                | CS0 A_DQ14 TX de-skew |

**DDRPHY REG83**

Address: Operational Base + offset (0x020c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>    |
|------------|-------------|--------------------|-----------------------|
| 31:8       | RO          | 0x0                | reserved              |
| 7:4        | RW          | 0x7                | CS0_A_DQ15 RX de-skew |
| 3:0        | RW          | 0x7                | CS0 A_DQ15 TX de-skew |

**DDRPHY REG84**

Address: Operational Base + offset (0x0210)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>    |
|------------|-------------|--------------------|-----------------------|
| 31:8       | RO          | 0x0                | reserved              |
| 7:4        | RW          | 0x7                | CS0 A_DQS1 RX de-skew |
| 3:0        | RW          | 0x7                | CS0 A_DQS1 TX de-skew |

**DDRPHY REG85**

Address: Operational Base + offset (0x0214)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>    |
|------------|-------------|--------------------|-----------------------|
| 31:4       | RO          | 0x0                | reserved              |
| 3:0        | RW          | 0x7                | CS0 A_DQSB1 TX de-ske |

**DDRPHY REG86**

Address: Operational Base + offset (0x0218)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>   |
|------------|-------------|--------------------|----------------------|
| 31:8       | RO          | 0x0                | reserved             |
| 7:4        | RW          | 0x7                | CS0 B_DM0 RX de-skew |
| 3:0        | RW          | 0x7                | CS0 B_DM0 TX de-skew |

**DDRPHY\_REG87**

Address: Operational Base + offset (0x021c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>   |
|------------|-------------|--------------------|----------------------|
| 31:8       | RO          | 0x0                | reserved             |
| 7:4        | RW          | 0x7                | CS0 B_DQ0 RX de-skew |
| 3:0        | RW          | 0x7                | CS0 B_DQ0 TX de-skew |

**DDRPHY\_REG88**

Address: Operational Base + offset (0x0220)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>   |
|------------|-------------|--------------------|----------------------|
| 31:8       | RO          | 0x0                | reserved             |
| 7:4        | RW          | 0x7                | CS0 B_DQ1 RX de-skew |
| 3:0        | RW          | 0x7                | CS0 B_DQ1 TX de-skew |

**DDRPHY\_REG89**

Address: Operational Base + offset (0x0224)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>    |
|------------|-------------|--------------------|-----------------------|
| 31:8       | RO          | 0x0                | reserved              |
| 7:4        | RW          | 0x7                | CS0 B_DQ2 RX de-skew  |
| 3:0        | RW          | 0x7                | FCS0 B_DQ2 TX de-skew |

**DDRPHY\_REG8A**

Address: Operational Base + offset (0x0228)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>   |
|------------|-------------|--------------------|----------------------|
| 31:8       | RO          | 0x0                | reserved             |
| 7:4        | RW          | 0x7                | CS0 B_DQ3 RX de-skew |
| 3:0        | RW          | 0x7                | CS0 B_DQ3 TX de-skew |

**DDRPHY\_REG8B**

Address: Operational Base + offset (0x022c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>   |
|------------|-------------|--------------------|----------------------|
| 31:8       | RO          | 0x0                | reserved             |
| 7:4        | RW          | 0x7                | CS0 B_DQ4 RX de-skew |
| 3:0        | RW          | 0x7                | CS0 B_DQ4 TX de-skew |

**DDRPHY\_REG8C**

Address: Operational Base + offset (0x0230)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>   |
|------------|-------------|--------------------|----------------------|
| 31:8       | RO          | 0x0                | reserved             |
| 7:4        | RW          | 0x7                | CS0 B_DQ5 RX de-skew |
| 3:0        | RW          | 0x7                | CS0 B_DQ5 TX de-skew |

**DDRPHY REG8D**

Address: Operational Base + offset (0x0234)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>   |
|------------|-------------|--------------------|----------------------|
| 31:8       | RO          | 0x0                | reserved             |
| 7:4        | RW          | 0x7                | CS0 B_DQ6 RX de-skew |
| 3:0        | RW          | 0x7                | CS0 B_DQ6 TX de-skew |

**DDRPHY REG8E**

Address: Operational Base + offset (0x0238)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>   |
|------------|-------------|--------------------|----------------------|
| 31:8       | RO          | 0x0                | reserved             |
| 7:4        | RW          | 0x7                | CS0 B_DQ7 RX de-skew |
| 3:0        | RW          | 0x7                | CS0 B_DQ7 TX de-skew |

**DDRPHY REG8F**

Address: Operational Base + offset (0x023c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>    |
|------------|-------------|--------------------|-----------------------|
| 31:8       | RO          | 0x0                | reserved              |
| 7:4        | RW          | 0x7                | CS0 B_DQS0 RX de-skew |
| 3:0        | RW          | 0x7                | CS0 B_DQS0 TX de-skew |

**DDRPHY REG90**

Address: Operational Base + offset (0x0240)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>     |
|------------|-------------|--------------------|------------------------|
| 31:4       | RO          | 0x0                | reserved               |
| 3:0        | RW          | 0x7                | CS0 B_DQSB0 TX de-skew |

**DDRPHY REG91**

Address: Operational Base + offset (0x0244)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>   |
|------------|-------------|--------------------|----------------------|
| 31:8       | RO          | 0x0                | reserved             |
| 7:4        | RW          | 0x7                | CS0 B_DM1 RX de-skew |
| 3:0        | RW          | 0x7                | CS0 B_DM1 TX de-skew |

**DDRPHY REG92**

Address: Operational Base + offset (0x0248)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>   |
|------------|-------------|--------------------|----------------------|
| 31:8       | RO          | 0x0                | reserved             |
| 7:4        | RW          | 0x7                | CS0 B_DQ8 RX de-skew |
| 3:0        | RW          | 0x7                | CS0 B_DQ8 TX de-skew |

**DDRPHY REG93**

Address: Operational Base + offset (0x024c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>   |
|------------|-------------|--------------------|----------------------|
| 31:8       | RO          | 0x0                | reserved             |
| 7:4        | RW          | 0x7                | CS0 B_DQ9 RX de-skew |
| 3:0        | RW          | 0x7                | CS0 B_DQ9 TX de-skew |

**DDRPHY REG94**

Address: Operational Base + offset (0x0250)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>    |
|------------|-------------|--------------------|-----------------------|
| 31:8       | RO          | 0x0                | reserved              |
| 7:4        | RW          | 0x7                | CS0 B_DQ10 RX de-skew |
| 3:0        | RW          | 0x7                | CS0 B_DQ10 TX de-skew |

**DDRPHY REG95**

Address: Operational Base + offset (0x0254)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>    |
|------------|-------------|--------------------|-----------------------|
| 31:8       | RO          | 0x0                | reserved              |
| 7:4        | RW          | 0x7                | CS0 B_DQ11 RX de-skew |
| 3:0        | RW          | 0x7                | CS0 B_DQ11 TX de-skew |

**DDRPHY REG96**

Address: Operational Base + offset (0x0258)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>    |
|------------|-------------|--------------------|-----------------------|
| 31:8       | RO          | 0x0                | reserved              |
| 7:4        | RW          | 0x7                | CS0 B_DQ12 RX de-skew |
| 3:0        | RW          | 0x7                | CS0 B_DQ12 TX de-skew |

**DDRPHY REG97**

Address: Operational Base + offset (0x025c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>    |
|------------|-------------|--------------------|-----------------------|
| 31:8       | RO          | 0x0                | reserved              |
| 7:4        | RW          | 0x7                | CS0 B_DQ13 RX de-skew |
| 3:0        | RW          | 0x7                | CS0 B_DQ13 TX de-skew |

**DDRPHY REG98**

Address: Operational Base + offset (0x0260)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>    |
|------------|-------------|--------------------|-----------------------|
| 31:8       | RO          | 0x0                | reserved              |
| 7:4        | RW          | 0x7                | CS0 B_DQ14 RX de-skew |
| 3:0        | RW          | 0x7                | CS0 B_DQ14 TX de-skew |

**DDRPHY REG99**

Address: Operational Base + offset (0x0264)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>    |
|------------|-------------|--------------------|-----------------------|
| 31:8       | RO          | 0x0                | reserved              |
| 7:4        | RW          | 0x7                | CS0 B_DQ15 RX de-skew |
| 3:0        | RW          | 0x7                | CS0 B_DQ15 TX de-skew |

**DDRPHY REG9A**

Address: Operational Base + offset (0x0268)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>    |
|------------|-------------|--------------------|-----------------------|
| 31:8       | RO          | 0x0                | reserved              |
| 7:4        | RW          | 0x7                | CS0 B_DQS1 RX de-skew |
| 3:0        | RW          | 0x7                |                       |

**DDRPHY REG9B**

Address: Operational Base + offset (0x026c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>     |
|------------|-------------|--------------------|------------------------|
| 31:4       | RO          | 0x0                | reserved               |
| 3:0        | RW          | 0x7                | CS0 B_DQSB1 TX de-skew |

**DDRPHY REGA3**

Address: Operational Base + offset (0x028c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------|
| 31:6       | RO          | 0x0                | reserved                                                             |
| 5          | RW          | 0x1                | Channel A 16bit DQ VREF select<br>1: internal mode; 0: external mode |
| 4:0        | RW          | 0x10               | Channel A 16bit DQ VREF value.<br>VREF value=(reg_value/32)*VDDQ     |

**DDRPHY REGAE**

Address: Operational Base + offset (0x02b8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------|
| 31:6       | RO          | 0x0                | reserved                                                             |
| 5          | RW          | 0x0                | Channel B 16bit DQ VREF select.<br>1: internal mode 0: external mode |
| 4:0        | RW          | 0x00               | Channel B 16bit DQ VREF value<br>VREF value=(reg_value/32)*VDDQ      |

**DDRPHY REGB0**

Address: Operational Base + offset (0x02c0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b> |
|------------|-------------|--------------------|--------------------|
| 31:8       | RO          | 0x0                | reserved           |
| 7:4        | RW          | 0x7                | A1 de-skew         |
| 3:0        | RW          | 0x7                | A0 de-skew         |

**DDRPHY REGB1**

Address: Operational Base + offset (0x02c4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b> |
|------------|-------------|--------------------|--------------------|
| 31:8       | RO          | 0x0                | reserved           |
| 7:4        | RW          | 0x7                | A3 de-skew         |
| 3:0        | RW          | 0x7                | A2 de-skew         |

**DDRPHY REGB2**

Address: Operational Base + offset (0x02c8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b> |
|------------|-------------|--------------------|--------------------|
| 31:8       | RO          | 0x0                | reserved           |
| 7:4        | RW          | 0x7                | A5 de-skew         |
| 3:0        | RW          | 0x7                | A4 de-skew         |

**DDRPHY REGB3**

Address: Operational Base + offset (0x02cc)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b> |
|------------|-------------|--------------------|--------------------|
| 31:8       | RO          | 0x0                | reserved           |
| 7:4        | RW          | 0x7                | A7 de-skew         |
| 3:0        | RW          | 0x7                | A6 de-skew         |

**DDRPHY REGB4**

Address: Operational Base + offset (0x02d0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b> |
|------------|-------------|--------------------|--------------------|
| 31:8       | RO          | 0x0                | reserved           |
| 7:4        | RW          | 0x7                | A9 de-skew         |
| 3:0        | RW          | 0x7                | A8 de-skew         |

**DDRPHY REGB5**

Address: Operational Base + offset (0x02d4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b> |
|------------|-------------|--------------------|--------------------|
| 31:8       | RO          | 0x0                | reserved           |
| 7:4        | RW          | 0x7                | A11 de-skew        |
| 3:0        | RW          | 0x7                | A10 de-skew        |

**DDRPHY REGB6**

Address: Operational Base + offset (0x02d8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b> |
|------------|-------------|--------------------|--------------------|
| 31:8       | RO          | 0x0                | reserved           |
| 7:4        | RW          | 0x7                | A13 de-skew        |
| 3:0        | RW          | 0x7                | A12 de-skew        |

**DDRPHY REGB7**

Address: Operational Base + offset (0x02dc)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b> |
|------------|-------------|--------------------|--------------------|
| 31:8       | RO          | 0x0                | reserved           |
| 7:4        | RW          | 0x7                | A15 de-skew        |
| 3:0        | RW          | 0x7                | A14 de-skew        |

**DDRPHY REGB8**

Address: Operational Base + offset (0x02e0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b> |
|------------|-------------|--------------------|--------------------|
| 31:8       | RO          | 0x0                | reserved           |
| 7:4        | RW          | 0x7                | B1 de-skew         |
| 3:0        | RW          | 0x7                | B0 de-skew         |

**DDRPHY REGB9**

Address: Operational Base + offset (0x02e4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b> |
|------------|-------------|--------------------|--------------------|
| 31:8       | RO          | 0x0                | reserved           |
| 7:4        | RW          | 0x7                | RAS# de-skew       |
| 3:0        | RW          | 0x7                | B2 de-skew         |

**DDRPHY REGBA**

Address: Operational Base + offset (0x02e8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b> |
|------------|-------------|--------------------|--------------------|
| 31:8       | RO          | 0x0                | reserved           |
| 7:4        | RW          | 0x7                | WE# de-skew        |
| 3:0        | RW          | 0x7                | CAS# de-skew       |

**DDRPHY REGBB**

Address: Operational Base + offset (0x02ec)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b> |
|------------|-------------|--------------------|--------------------|
| 31:8       | RO          | 0x0                | reserved           |
| 7:4        | RW          | 0x7                | CKB de-skew        |
| 3:0        | RW          | 0x7                | CK de-skew         |

**DDRPHY REGBC**

Address: Operational Base + offset (0x02f0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b> |
|------------|-------------|--------------------|--------------------|
| 31:8       | RO          | 0x0                | reserved           |
| 7:4        | RW          | 0x7                | CKE de-skew        |
| 3:0        | RW          | 0x7                | ODT0 de-skew       |

**DDRPHY REGBD**

Address: Operational Base + offset (0x02f4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b> |
|------------|-------------|--------------------|--------------------|
| 31:8       | RO          | 0x0                | reserved           |
| 7:4        | RW          | 0x7                | CSB0 de-skew       |
| 3:0        | RW          | 0x7                | RESETN de-skew     |

**DDRPHY REGBE**

Address: Operational Base + offset (0x02f8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b> |
|------------|-------------|--------------------|--------------------|
| 31:8       | RO          | 0x0                | reserved           |
| 7:4        | RW          | 0x7                | CSB1 de-skew       |
| 3:0        | RW          | 0x7                | ODT1 de-skew       |

**DDRPHY REGCO**

Address: Operational Base + offset (0x0300)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>   |
|------------|-------------|--------------------|----------------------|
| 31:8       | RO          | 0x0                | reserved             |
| 7:4        | RW          | 0x7                | CS1 A_DM0 RX de-skew |
| 3:0        | RW          | 0x7                | CS1 A_DM0 TX de-skew |

**DDRPHY REGC1**

Address: Operational Base + offset (0x0304)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>   |
|------------|-------------|--------------------|----------------------|
| 31:8       | RO          | 0x0                | reserved             |
| 7:4        | RW          | 0x7                | CS1 A_DQ0 RX de-skew |
| 3:0        | RW          | 0x7                | CS1 A_DQ0 TX de-skew |

**DDRPHY REGC2**

Address: Operational Base + offset (0x0308)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>   |
|------------|-------------|--------------------|----------------------|
| 31:8       | RO          | 0x0                | reserved             |
| 7:4        | RW          | 0x7                | CS1 A_DQ1 RX de-skew |
| 3:0        | RW          | 0x7                | CS1 A_DQ1 TX de-skew |

**DDRPHY REGC3**

Address: Operational Base + offset (0x030c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>   |
|------------|-------------|--------------------|----------------------|
| 31:8       | RO          | 0x0                | reserved             |
| 7:4        | RW          | 0x7                | CS1 A_DQ2 RX de-skew |
| 3:0        | RW          | 0x7                | CS1 A_DQ2 TX de-skew |

**DDRPHY REGC4**

Address: Operational Base + offset (0x0310)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>   |
|------------|-------------|--------------------|----------------------|
| 31:8       | RO          | 0x0                | reserved             |
| 7:4        | RW          | 0x7                | CS1 A_DQ3 RX de-skew |
| 3:0        | RW          | 0x7                | CS1 A_DQ3 TX de-skew |

**DDRPHY REGC5**

Address: Operational Base + offset (0x0314)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>   |
|------------|-------------|--------------------|----------------------|
| 31:8       | RO          | 0x0                | reserved             |
| 7:4        | RW          | 0x7                | CS1 A_DQ4 RX de-skew |
| 3:0        | RW          | 0x7                | CS1 A_DQ4 TX de-skew |

**DDRPHY REGC6**

Address: Operational Base + offset (0x0318)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>   |
|------------|-------------|--------------------|----------------------|
| 31:8       | RO          | 0x0                | reserved             |
| 7:4        | RW          | 0x7                | CS1 A_DQ5 RX de-skew |
| 3:0        | RW          | 0x7                | CS1 A_DQ5 TX de-skew |

**DDRPHY REGC7**

Address: Operational Base + offset (0x031c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>   |
|------------|-------------|--------------------|----------------------|
| 31:8       | RO          | 0x0                | reserved             |
| 7:4        | RW          | 0x7                | CS1 A_DQ6 RX de-skew |
| 3:0        | RW          | 0x7                | CS1 A_DQ6 TX de-skew |

**DDRPHY REGC8**

Address: Operational Base + offset (0x0320)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>   |
|------------|-------------|--------------------|----------------------|
| 31:8       | RO          | 0x0                | reserved             |
| 7:4        | RW          | 0x7                | CS1 A_DQ7 RX de-skew |
| 3:0        | RW          | 0x7                | CS1 A_DQ7 TX de-skew |

**DDRPHY REGC9**

Address: Operational Base + offset (0x0324)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>    |
|------------|-------------|--------------------|-----------------------|
| 31:8       | RO          | 0x0                | reserved              |
| 7:4        | RW          | 0x7                | CS1 A_DQS0 RX de-skew |
| 3:0        | RW          | 0x7                | CS1 A_DQS0 TX de-skew |

**DDRPHY REGCA**

Address: Operational Base + offset (0x0328)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>     |
|------------|-------------|--------------------|------------------------|
| 31:4       | RO          | 0x0                | reserved               |
| 3:0        | RW          | 0x7                | CS1 A_DQSB0 TX de-skew |

**DDRPHY REGCB**

Address: Operational Base + offset (0x032c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>   |
|------------|-------------|--------------------|----------------------|
| 31:8       | RO          | 0x0                | reserved             |
| 7:4        | RW          | 0x7                | CS1 A_DM1 RX de-skew |
| 3:0        | RW          | 0x7                | CS1 A_DM1 TX de-skew |

**DDRPHY REGCC**

Address: Operational Base + offset (0x0330)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>   |
|------------|-------------|--------------------|----------------------|
| 31:8       | RO          | 0x0                | reserved             |
| 7:4        | RW          | 0x7                | CS1 A_DQ8 RX de-skew |
| 3:0        | RW          | 0x7                | CS1 A_DQ8 TX de-skew |

**DDRPHY REGCD**

Address: Operational Base + offset (0x0334)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>   |
|------------|-------------|--------------------|----------------------|
| 31:8       | RO          | 0x0                | reserved             |
| 7:4        | RW          | 0x7                | CS1 A_DQ9 RX de-skew |
| 3:0        | RW          | 0x7                | CS1 A_DQ9 TX de-skew |

**DDRPHY REGCE**

Address: Operational Base + offset (0x0338)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>    |
|------------|-------------|--------------------|-----------------------|
| 31:8       | RO          | 0x0                | reserved              |
| 7:4        | RW          | 0x7                | CS1 A_DQ10 RX de-skew |
| 3:0        | RW          | 0x7                | CS1 A_DQ10 TX de-skew |

**DDRPHY REGCF**

Address: Operational Base + offset (0x033c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>    |
|------------|-------------|--------------------|-----------------------|
| 31:8       | RO          | 0x0                | reserved              |
| 7:4        | RW          | 0x7                | CS1 A_DQ11 RX de-skew |
| 3:0        | RW          | 0x7                | CS1 A_DQ11 TX de-skew |

**DDRPHY REGD0**

Address: Operational Base + offset (0x0340)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>    |
|------------|-------------|--------------------|-----------------------|
| 31:8       | RO          | 0x0                | reserved              |
| 7:4        | RW          | 0x7                | CS1 A_DQ12 RX de-skew |
| 3:0        | RW          | 0x7                | CS1 A_DQ12 TX de-skew |

**DDRPHY REGD1**

Address: Operational Base + offset (0x0344)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>    |
|------------|-------------|--------------------|-----------------------|
| 31:8       | RO          | 0x0                | reserved              |
| 7:4        | RW          | 0x7                | CS1 A_DQ13 RX de-skew |
| 3:0        | RW          | 0x7                | CS1 A_DQ13 TX de-skew |

**DDRPHY REGD2**

Address: Operational Base + offset (0x0348)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>    |
|------------|-------------|--------------------|-----------------------|
| 31:8       | RO          | 0x0                | reserved              |
| 7:4        | RW          | 0x7                | CS1 A_DQ14 RX de-skew |
| 3:0        | RW          | 0x7                | CS1 A_DQ14 TX de-skew |

**DDRPHY REGD3**

Address: Operational Base + offset (0x034c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>    |
|------------|-------------|--------------------|-----------------------|
| 31:8       | RO          | 0x0                | reserved              |
| 7:4        | RW          | 0x7                | A_DQ15 RX de-skew     |
| 3:0        | RW          | 0x7                | CS1 A_DQ15 TX de-skew |

**DDRPHY REGD4**

Address: Operational Base + offset (0x0350)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>    |
|------------|-------------|--------------------|-----------------------|
| 31:8       | RO          | 0x0                | reserved              |
| 7:4        | RW          | 0x7                | CS1 A_DQS1 RX de-skew |
| 3:0        | RW          | 0x7                | CS1 A_DQS1 TX de-skew |

**DDRPHY REGD5**

Address: Operational Base + offset (0x0354)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>     |
|------------|-------------|--------------------|------------------------|
| 31:4       | RO          | 0x0                | reserved               |
| 3:0        | RW          | 0x7                | CS1 A_DQSB1 TX de-skew |

**DDRPHY REGD6**

Address: Operational Base + offset (0x0358)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>   |
|------------|-------------|--------------------|----------------------|
| 31:8       | RO          | 0x0                | reserved             |
| 7:4        | RW          | 0x7                | CS1 B_DM0 RX de-skew |
| 3:0        | RW          | 0x7                | CS1 B_DM0 TX de-skew |

**DDRPHY REGD7**

Address: Operational Base + offset (0x035c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>   |
|------------|-------------|--------------------|----------------------|
| 31:8       | RO          | 0x0                | reserved             |
| 7:4        | RW          | 0x7                | CS1 B_DQ0 RX de-skew |
| 3:0        | RW          | 0x7                | CS1 B_DQ0 TX de-skew |

**DDRPHY REGD8**

Address: Operational Base + offset (0x0360)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>   |
|------------|-------------|--------------------|----------------------|
| 31:8       | RO          | 0x0                | reserved             |
| 7:4        | RW          | 0x7                | CS1 B_DQ1 RX de-skew |
| 3:0        | RW          | 0x7                | CS1 B_DQ1 TX de-skew |

**DDRPHY REGD9**

Address: Operational Base + offset (0x0364)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>   |
|------------|-------------|--------------------|----------------------|
| 31:8       | RO          | 0x0                | reserved             |
| 7:4        | RW          | 0x7                | CS1 B_DQ2 RX de-skew |
| 3:0        | RW          | 0x7                | CS1 B_DQ2 TX de-skew |

**DDRPHY REGDA**

Address: Operational Base + offset (0x0368)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>   |
|------------|-------------|--------------------|----------------------|
| 31:8       | RO          | 0x0                | reserved             |
| 7:4        | RW          | 0x7                | CS1 B_DQ3 RX de-skew |
| 3:0        | RW          | 0x7                | CS1 B_DQ3 TX de-skew |

**DDRPHY REGDB**

Address: Operational Base + offset (0x036c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>   |
|------------|-------------|--------------------|----------------------|
| 31:8       | RO          | 0x0                | reserved             |
| 7:4        | RW          | 0x7                | CS1 B_DQ4 RX de-skew |
| 3:0        | RW          | 0x7                | CS1 B_DQ4 TX de-skew |

**DDRPHY REGDC**

Address: Operational Base + offset (0x0370)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>   |
|------------|-------------|--------------------|----------------------|
| 31:8       | RO          | 0x0                | reserved             |
| 7:4        | RW          | 0x7                | CS1_B_DQ5 RX de-skew |
| 3:0        | RW          | 0x7                | CS1_B_DQ5 TX de-skew |

**DDRPHY\_REGDD**

Address: Operational Base + offset (0x0374)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>   |
|------------|-------------|--------------------|----------------------|
| 31:8       | RO          | 0x0                | reserved             |
| 7:4        | RW          | 0x7                | CS1_B_DQ6 RX de-skew |
| 3:0        | RW          | 0x7                | CS1_B_DQ6 TX de-skew |

**DDRPHY\_REGDE**

Address: Operational Base + offset (0x0378)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>   |
|------------|-------------|--------------------|----------------------|
| 31:8       | RO          | 0x0                | reserved             |
| 7:4        | RW          | 0x7                | CS1_B_DQ7 RX de-skew |
| 3:0        | RW          | 0x0                | CS1_B_DQ7 TX de-skew |

**DDRPHY\_REGDF**

Address: Operational Base + offset (0x037c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>    |
|------------|-------------|--------------------|-----------------------|
| 31:8       | RO          | 0x0                | reserved              |
| 7:4        | RW          | 0x7                | CS1_B_DQS0 RX de-skew |
| 3:0        | RW          | 0x7                | CS1_B_DQS0 TX de-skew |

**DDRPHY\_REGE0**

Address: Operational Base + offset (0x0380)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>     |
|------------|-------------|--------------------|------------------------|
| 31:4       | RO          | 0x0                | reserved               |
| 3:0        | RW          | 0x7                | CS1_B_DQSB0 TX de-skew |

**DDRPHY\_REGE1**

Address: Operational Base + offset (0x0384)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>   |
|------------|-------------|--------------------|----------------------|
| 31:8       | RO          | 0x0                | reserved             |
| 7:4        | RW          | 0x7                | CS1_B_DM1 RX de-skew |
| 3:0        | RW          | 0x7                | CS1_B_DM1 TX de-skew |

**DDRPHY\_REGE2**

Address: Operational Base + offset (0x0388)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>   |
|------------|-------------|--------------------|----------------------|
| 31:8       | RO          | 0x0                | reserved             |
| 7:4        | RW          | 0x7                | CS1 B_DQ8 RX de-skew |
| 3:0        | RW          | 0x7                | CS1 B_DQ8 TX de-skew |

**DDRPHY REGE3**

Address: Operational Base + offset (0x038c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>   |
|------------|-------------|--------------------|----------------------|
| 31:8       | RO          | 0x0                | reserved             |
| 7:4        | RW          | 0x7                | CS1 B_DQ9 RX de-skew |
| 3:0        | RW          | 0x7                | CS1 B_DQ9 TX de-skew |

**DDRPHY REGE4**

Address: Operational Base + offset (0x0390)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>    |
|------------|-------------|--------------------|-----------------------|
| 31:8       | RO          | 0x0                | reserved              |
| 7:4        | RW          | 0x7                | CS1 B_DQ10 RX de-skew |
| 3:0        | RW          | 0x7                | CS1 B_DQ10 TX de-skew |

**DDRPHY REGE5**

Address: Operational Base + offset (0x0394)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>    |
|------------|-------------|--------------------|-----------------------|
| 31:8       | RO          | 0x0                | reserved              |
| 7:4        | RW          | 0x7                | CS1 B_DQ11 RX de-skew |
| 3:0        | RW          | 0x7                | CS1 B_DQ11 TX de-skew |

**DDRPHY REGE6**

Address: Operational Base + offset (0x0398)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>    |
|------------|-------------|--------------------|-----------------------|
| 31:8       | RO          | 0x0                | reserved              |
| 7:4        | RW          | 0x7                | CS1 B_DQ12 RX de-skew |
| 3:0        | RW          | 0x7                | CS1 B_DQ12 TX de-skew |

**DDRPHY REGE7**

Address: Operational Base + offset (0x039c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>    |
|------------|-------------|--------------------|-----------------------|
| 31:8       | RO          | 0x0                | reserved              |
| 7:4        | RW          | 0x7                | CS1 B_DQ13 RX de-skew |
| 3:0        | RW          | 0x7                | CS1 B_DQ13 TX de-skew |

**DDRPHY REGE8**

Address: Operational Base + offset (0x03a0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>    |
|------------|-------------|--------------------|-----------------------|
| 31:8       | RO          | 0x0                | reserved              |
| 7:4        | RW          | 0x7                | CS1 B_DQ14 RX de-skew |
| 3:0        | RW          | 0x7                | CS1 B_DQ14 TX de-skew |

**DDRPHY REGE9**

Address: Operational Base + offset (0x03a4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>    |
|------------|-------------|--------------------|-----------------------|
| 31:8       | RO          | 0x0                | reserved              |
| 7:4        | RW          | 0x7                | CS1 B_DQ15 RX de-skew |
| 3:0        | RW          | 0x7                | CS1 B_DQ15 TX de-skew |

**DDRPHY REGEA**

Address: Operational Base + offset (0x03a8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>    |
|------------|-------------|--------------------|-----------------------|
| 31:8       | RO          | 0x0                | reserved              |
| 7:4        | RW          | 0x7                | CS1 B_DQS1 RX de-skew |
| 3:0        | RW          | 0x7                | CS1 B_DQS1 TX de-skew |

**DDRPHY REGEB**

Address: Operational Base + offset (0x03ac)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>     |
|------------|-------------|--------------------|------------------------|
| 31:4       | RO          | 0x0                | reserved               |
| 3:0        | RW          | 0x7                | CS1 B_DQSB1 TX de-skew |

**DDRPHY REGEC**

Address: Operational Base + offset (0x03b0)

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

**DDRPHY REGFO**

Address: Operational Base + offset (0x03c0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                      |
|------------|-------------|--------------------|-----------------------------------------|
| 31:4       | RO          | 0x0                | reserved                                |
| 3          | RO          | 0x0                | Channel B High 8bit write leveling done |
| 2          | RO          | 0x0                | Channel B Low 8bit write leveling done  |
| 1          | RO          | 0x0                | Channel A High 8bit write leveling done |
| 0          | RO          | 0x0                | Channel A Low 8bit write leveling done  |

**DDRPHY REGF1**

Address: Operational Base + offset (0x03c4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                           |
|------------|-------------|--------------------|----------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                     |
| 7:4        | RO          | 0x0                | Channel A High 8bit write leveling dqs value |
| 3:0        | RO          | 0x0                | Channel A Low 8bit write leveling dqs value  |

**DDRPHY REGF2**

Address: Operational Base + offset (0x03c8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                           |
|------------|-------------|--------------------|----------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                     |
| 7:4        | RO          | 0x0                | Channel B High 8bit write leveling dqs value |
| 3:0        | RO          | 0x0                | Channel B Low 8bit write leveling dqs value  |

**DDRPHY REGF3**

Address: Operational Base + offset (0x03cc)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                             |
| 7:4        | RO          | 0x0                | Channel A High 8bit write leveling dqs value for CS1 |
| 3:0        | RO          | 0x0                | Channel A Low 8bit write leveling dqs value for CS1  |

**DDRPHY REGF4**

Address: Operational Base + offset (0x03d0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                             |
| 7:4        | RO          | 0x0                | Channel B High 8bit write leveling dqs value for CS1 |
| 3:0        | RO          | 0x0                | Channel B Low 8bit write leveling dqs value for CS1  |

**DDRPHY REGFA**

Address: Operational Base + offset (0x03e8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                      |
|------------|-------------|--------------------|---------------------------------------------------------|
| 31:4       | RO          | 0x0                | reserved                                                |
| 3          | RO          | 0x0                | Channel B High 8bit dqs gate sample dqs value(idqs) (3) |
| 2          | RO          | 0x0                | Channel B Low 8bit dqs gate sample dqs value(idqs) (3)  |
| 1          | RO          | 0x0                | Channel A High 8bit dqs gate sample dqs value(idqs) (3) |
| 0          | RO          | 0x0                | Channel A Low 8bit dqs gate sample dqs value(idqs) (3)  |

**DDRPHY REGFB**

Address: Operational Base + offset (0x03ec)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                                        |
| 7:5        | RO          | 0x0                | Calibration get the dll configure channel A low<br>8bit(3)      |
| 4:3        | RO          | 0x0                | Calibration get the ophsel configure channel A low<br>8bit(3)   |
| 2:0        | RO          | 0x0                | Calibration get the cyclesel configure channel A<br>low 8bit(3) |

**DDRPHY REGFC**

Address: Operational Base + offset (0x03f0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                               |
|------------|-------------|--------------------|------------------------------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                                         |
| 7:5        | RO          | 0x0                | Calibration get the dll configure channel A high<br>8bit(3)      |
| 4:3        | RO          | 0x0                | Calibration get the ophsel configure channel A high<br>8bit(3)   |
| 2:0        | RO          | 0x0                | Calibration get the cyclesel configure channel A<br>high 8bit(3) |

**DDRPHY REGFD**

Address: Operational Base + offset (0x03f4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                                        |
| 7:5        | RO          | 0x0                | Calibration get the dll configure channel B low<br>8bit(3)      |
| 4:3        | RO          | 0x0                | Calibration get the ophsel configure channel B low<br>8bit(3)   |
| 2:0        | RO          | 0x0                | Calibration get the cyclesel configure channel B<br>low 8bit(3) |

**DDRPHY REGFE**

Address: Operational Base + offset (0x03f8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                               |
|------------|-------------|--------------------|------------------------------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                                         |
| 7:5        | RO          | 0x0                | Calibration get the dll configure channel B high<br>8bit(3)      |
| 4:3        | RO          | 0x0                | Calibration get the ophsel configure channel B high<br>8bit(3)   |
| 2:0        | RO          | 0x0                | Calibration get the cyclesel configure channel B<br>high 8bit(3) |

**DDRPHY REGFF**

Address: Operational Base + offset (0x03fc)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:4       | RO          | 0x0                | reserved                             |
| 3          | RO          | 0x0                | Channel B High 8bit Calibration done |
| 2          | RO          | 0x0                | Channel B Low 8bit Calibration done  |
| 1          | RO          | 0x0                | Channel A High 8bit Calibration done |
| 0          | RO          | 0x0                | Channel A Low 8bit Calibration done  |

## 2.5 Interface Description

DDR IOs are listed as following Table.

Table 2-1 DDR IO description

| <b>Pin Name</b> | <b>Description</b>                                        |
|-----------------|-----------------------------------------------------------|
| CK              | Positive differential clock                               |
| CKB             | Negative differential clock                               |
| CKE             | Active-high clock enable signal for two chip select.      |
| CSBi (i=0,1)    | Active-low chip select signal. There are two chip select. |
| RASB            | Active-low row address strobe                             |
| CASB            | Active-low column address strobe                          |
| WEB             | Active-low write enable strobe                            |
| BA[2:0]         | Bank address signal                                       |
| A[15:0]         | Address signal                                            |
| DQ[31:0]        | Bidirectional data line                                   |
| DQS[3:0]        | Positive differential bidirectional data strobes          |
| DQSB[3:0]       | Negative differential bidirectional data strobes.         |
| DM[3:0]         | Active-low data mask signal.                              |
| ODTi (i=0,1)    | On-Die Termination output signal for two chip select.     |
| RESETN          | Reset signal.                                             |

The DDR4 Interface of DDR PHY is reused with DDR3/DDR3L, so the mapping relation between the DDR4 and DDR3/DDR3L show in the following table

Table 2-2 DDR4 IO Mapping Table

| <b>DDR4</b> | <b>DDR3/DDR3L</b> |
|-------------|-------------------|
| A0          | A9                |
| A1          | A14               |
| A2          | A13               |
| A3          | A11               |
| A4          | A2                |
| A5          | A4                |
| A6          | A3                |
| A7          | A6                |
| A8          | A5                |
| A9          | A1                |
| A10         | A0                |
| A11         | A7                |
| A12         | CASB              |
| A13         | A8                |
| WEB/A14     | ODT0              |
| CASB/A15    | BA1               |
| RASB/A16    | CKE               |
| BA0         | BA2               |
| BA1         | A12               |
| BG0         | BA0               |
| CK          | CK                |
| CKB         | CKB               |
| CKE         | RASB              |
| CSB0        | A10               |
| ODT0        | A15               |
| ACTN        | CSB0              |
| RESETN      | RESETN            |
| ODT1        | ODT1              |
| CSB1        | CSB1              |
| BG1         | WEB               |

## 2.6 Application Notes

### 2.6.1 Initialization

#### PCTL & DDR PHY Initialization

1. Assert the resets (presentn, core\_ddrc\_rstn and aresetn\_0 of PCTL)
2. Configure PLL of DDR PHY and wait PLL lock.
3. De-assert presentn if clocks are active and stable.
4. Initial PCTL register and PHY Register
5. Start PHY initialization with DFIMIS[5] register of PCTL
6. De-assert the remaining resets (core\_ddrc\_rstn and aresetn\_0 of PCTL)
7. Wait PCTL initialization done (STAT.operation\_mode==normal)
8. Start PHY dqs calibration with PHYREG02 register and wait calibration finish with PHYREGFF register.
9. (optional) After dqs calibration, start write leveling training with PHYREG02 register and wait write leveling training finish with PHYJREGF0 register.
10. Start Write and Read.

#### DDR3/DDR3L Initialization Sequence

The initialization steps for DDR3/DDR3L SDRAMs are as follows:

1. Power-up.
2. Maintain dfi\_reset\_n low for duration specified by INIT1.dram\_rstn\_x1024. Specification requires at least 200 us with stable power.
3. Issue NOP/deselect for duration specified by INIT0.pre\_cke\_x1024. Specification requires

- at least 500 us.
4. Assert CKE and issue NOP/deselect for INIT0.post\_cke\_x1024 (specification requires at least tXPR).
  5. Issue MRS (mode register set) command to load MR2 with INIT4.emr2 value followed by NOP/deselect for duration of DRAMTMG3.t\_mrd.
  6. Issue MRS command to load MR3 with INIT4.emr3 followed by NOP/deselect for duration of DRAMTMG3.t\_mrd.
  7. Issue MRS command to load MR1 with INIT4.emr followed by NOP/deselect for duration of DRAMTMG3.t\_mrd.
  8. Issue MRS command to load MR0 with INIT3.mr followed by NOP/deselect for duration of DRAMTMG3.t\_mod.
  9. Issue ZQCL command to start ZQ calibration and wait for INIT5.dev\_zqinit\_x32.
  10. Wait for INIT5.dev\_zqinit\_x32 counting to finish. Ensure wait from step 8 is larger than tDLLK.
  11. The PCTL controller is now ready for normal operation.

### **DDR4 Initialization Sequence**

The initialization steps for DDR4 SDRAMs are as follows:

1. Power-up.
2. Maintain dfi\_reset\_n low for duration specified by INIT1.dram\_rstn\_x1024. Specification requires at least 200 us with stable power.
3. Issue NOP/deselect for duration specified by INIT0.pre\_cke\_x1024. Specification requires at least 500 us.
4. Assert CKE and issue NOP/deselect for INIT0.post\_cke\_x1024 (specification requires at least tXPR).
5. Issue MRS (mode register set) command to load MR3 with INIT4.emr3 value followed by NOP/deselect for duration of DRAMTMG3.t\_mrd.
6. Issue MRS (mode register set) command to load MR6 with INIT7.mr6 value followed by NOP/deselect for duration of DRAMTMG3.t\_mrd.
7. Issue MRS (mode register set) command to load MR5 with INIT6.mr5 value followed by NOP/deselect for duration of DRAMTMG3.t\_mrd.
8. Issue MRS (mode register set) command to load MR4 with INIT7.mr4 value followed by NOP/deselect for duration of DRAMTMG3.t\_mrd.
9. Issue MRS command to load MR2 with INIT4.emr2 followed by NOP/deselect for duration of DRAMTMG3.t\_mrd.
10. Issue MRS command to load MR1 with INIT4.emr followed by NOP/deselect for duration of DRAMTMG3.t\_mrd.
11. Issue MRS command to load MR0 with INIT3.mr followed by NOP/deselect for duration of DRAMTMG3.t\_mod.
12. Issue ZQCL command to start ZQ calibration and wait for INIT5.dev\_zqinit\_x32.
13. Wait for INIT5.dev\_zqinit\_x32 counting to finish. Ensure wait from step 8 is larger than tDLLK.
14. The PCTL controller is now ready for normal operation.

### **LPDDR2/3 Initialization Sequence**

The initialization steps for LPDDR2/3 SDRAMs are as follows:

1. Power-up.
2. CKE is held low for a duration specified by INIT0.pre\_cke\_x1024. The clock is checked to be stable for duration specified by INIT2.min\_stable\_clock\_x1 (minimum of 5 clock cycles) prior to the first low to high transition of CKE.
3. Assert CKE for INIT0.post\_cke\_x1024 (specification requires at least 200 us).
4. A MRW (Reset) command is issued to MRW63 register. Values of MA<7:0> = 3FH and OP<7:0> = 00H is used for this command. The MRW reset command brings the device to the device auto initialization (resetting) state in the power-on initialization sequence.
5. Issue NOP/deselect for duration specified by INIT2.idle\_after\_reset\_x32 (specification requires 1 us minimum) and INIT5.max\_auto\_init\_x1024 (specification requires maximum time of 10 us).

6. An MRW ZQ initialization calibration command is issued to the memory to register MR10 to initiate the ZQ calibration. Values of MA<7:0> = 0AH and OP<7:0> = FFH is used for this command.
7. Issue NOP/deselect for duration specified by INIT5.dev\_zqinit\_x32 (specification requires a minimum time of 1us).
8. Program MR2 register by setting MR2 register to INIT3.emr followed by a NOP/deselect for a duration specified by DRAMTMG3.t\_mrw (typical value of 5 clock cycles).
9. Program MR1 register by setting MR1 register to INIT3.mr followed by a NOP/deselect for a duration specified by DRAMTMG3.t\_mrw (typical value of 5 clock cycles).
10. Program MR3 register by setting MR3 register to INIT4.emr2 followed by a NOP/deselect for a duration specified by DRAMTMG3.t\_mrw (typical value of 5 clock cycles).
11. Schedule multiple all bank refresh.
12. The PCTL controller is now ready for normal operation.

## 2.6.2 TX DLLs

All high speed IO signals' phase can be adjusted by TX DLLs. See the following table.

Table 2-3 DDR PHY TX DLLs Delay Step

| Offset | Bit | Control Signal Phase | Default | Description                     |
|--------|-----|----------------------|---------|---------------------------------|
| 0x4c   | 2~0 | CMD                  | 0x4     | CMD DLL delay step              |
| 0x50   | 2~0 | CK                   | 0x0     | CK DLL delay step               |
| 0x98   | 2~0 | A_DM0, A_DQ7~A_DQ0   | 0x4     | DM and DQ DLL Signal delay step |
| 0xd8   | 2~0 | A_DM1, A_DQ15~A_DQ8  | 0x4     |                                 |
| 0x118  | 2~0 | B_DM0, B_DQ7~B_DQ0   | 0x4     |                                 |
| 0x158  | 2~0 | B_DM1, B_DQ15~B_DQ8  | 0x4     |                                 |
| 0x9c   | 2~0 | A_DQS0, A_DQSB0      | 0x0     | TX DQS DLL Signal delay step    |
| 0xdc   | 2~0 | A_DQS1, A_DQSB1      | 0x0     |                                 |
| 0x11c  | 2~0 | B_DQS0, B_DQSB0      | 0x0     |                                 |
| 0x15c  | 2~0 | B_DQS1, B_DQSB1      | 0x0     |                                 |

Step 0x0 values means no phase delay, and 0x4 increases delay phase to 90 deg, 0x7 values corresponds to maximum phase delay. All DLLs having 8 delay steps which can get 90 deg phase delay by setting 0x4.

## 2.6.3 RX DLLs

The RX DLLs are used for sample RX DQS signals with proper phase delay and pulse edges. The DQS squelch (Rx Squelch) signal opens a window for passing RX DQS pulses, both RX DQS and DQS squelch signal phase can be adjusted by corresponding DLLs.

Table 2-4 DDR PHY RX DQS Delay Step

| Offset | Bit | Control Signal Phase       | Default | Description                                                         |
|--------|-----|----------------------------|---------|---------------------------------------------------------------------|
| 0xa0   | 1~0 | A_DQS0,A_DQSB0             | 0x1     | Read DQS DLL delay phase                                            |
| 0xe0   | 1~0 | A_DQS1,A_DQSB1             | 0x1     |                                                                     |
| 0x120  | 1~0 | A_DQS0,A_DQSB0             | 0x1     |                                                                     |
| 0x160  | 1~0 | A_DQS1,A_DQSB1             | 0x1     |                                                                     |
| 0xb0   | 7~5 | left channel A DQS gating  | 0x1     | CS0 DQS gating delay, unit x1 clock cycle                           |
| 0xf0   | 7~5 | right channel A DQS gating | 0x1     |                                                                     |
| 0x130  | 7~5 | left channel B DQS gating  | 0x1     |                                                                     |
| 0x170  | 7~5 | reft channel B DQS gating  | 0x1     |                                                                     |
| 0xb4   | 7~5 | left channel A DQS gating  | 0x1     | CS1 DQS gating delay, unit x1 clock cycle                           |
| 0xf4   | 7~5 | right channel A DQS gating | 0x1     |                                                                     |
| 0x134  | 7~5 | left channel B DQS gating  | 0x1     |                                                                     |
| 0x174  | 7~5 | reft channel B DQS gating  | 0x1     |                                                                     |
| 0xb0   | 4~3 | left channel A DQS gating  | 0x1     | CS0 additive and accumulative DQS gating delay, unit 4x clock cycle |
| 0xf0   | 4~3 | right channel A DQS gating | 0x1     |                                                                     |
| 0x130  | 4~3 | left channel B DQS gating  | 0x1     |                                                                     |

| Offset | Bit | Control Signal Phase       | Default | Description                                                         |
|--------|-----|----------------------------|---------|---------------------------------------------------------------------|
| 0x170  | 4~3 | reft channel B DQS gating  | 0x1     | CS1 additive and accumulative DQS gating delay, unit 4x clock cycle |
| 0x0b4  | 4~3 | left channel A DQS gating  | 0x1     |                                                                     |
| 0x0f4  | 4~3 | right channel A DQS gating | 0x1     |                                                                     |
| 0x134  | 4~3 | left channel B DQS gating  | 0x1     |                                                                     |
| 0x174  | 4~3 | reft channel B DQS gating  | 0x1     |                                                                     |
| 0x0b0  | 2~0 | left channel A DQS gating  | 0x4     | CS0 additive and accumulative DQS gating delay, unit per DLL step   |
| 0x0f0  | 2~0 | right channel A DQS gating | 0x4     |                                                                     |
| 0x130  | 2~0 | left channel B DQS gating  | 0x4     |                                                                     |
| 0x170  | 2~0 | reft channel B DQS gating  | 0x4     |                                                                     |
| 0x0b4  | 2~0 | left channel A DQS gating  | 0x4     | CS1 additive and accumulative DQS gating delay, unit per DLL step   |
| 0x0f4  | 2~0 | right channel A DQS gating | 0x4     |                                                                     |
| 0x134  | 2~0 | left channel B DQS gating  | 0x4     |                                                                     |
| 0x174  | 2~0 | reft channel B DQS gating  | 0x4     |                                                                     |

## 2.6.4 High Speed IO Drive Strength

The tuning range of driver resistance is 19.6ohm to  $\infty$ . By default, 0x14 is 37.6ohm for DDR3 DQ and CMD driver. When the control bit is set to be larger, the drive strength becomes stronger.

Table 2-5 CK/CMD Driver output resistance

| Offset | Bit | Default | Description                          |
|--------|-----|---------|--------------------------------------|
| 0x44   | 4~0 | 0x14    | adjustable CMD pull-down resistance  |
| 0x48   | 7~3 | 0x14    | adjustable CMD pull-up resistance    |
| 0x58   | 4~0 | 0x14    | adjustable CK pull-down resistance   |
| 0x60   | 4~0 | 0x14    | adjustable CK pull-up resistance     |
| 0x5c   | 6~4 | 0x04    | Adjust CMD/CK falling edge slew rate |
| 0x5c   | 2~0 | 0x04    | Adjust CMD/CK rising edge slew rate  |

Table 2-6 DM, DQ Signal Drive Strength Register

| Offset | Bit | Default | Description                                     |
|--------|-----|---------|-------------------------------------------------|
| 0x80   | 4~0 | 0x14    | pull-down driving resistance for A_DQ0~A_DQ7    |
| 0xbc   | 4~0 | 0x14    | pull-up driving resistance for A_DQ0~A_DQ7      |
| 0xc0   | 4~0 | 0x14    | pull-down driving resistance for A_DQ8~A_DQ15   |
| 0xfc   | 4~0 | 0x14    | pull-up driving resistance for A_DQ8~A_DQ15     |
| 0x100  | 4~0 | 0x14    | pull-down driving resistance for B_DQ0~B_DQ7    |
| 0x13c  | 4~0 | 0x14    | pull-up driving resistance for B_DQ0~B_DQ7      |
| 0x140  | 4~0 | 0x14    | pull-down driving resistance for B_DQ8~B_DQ15   |
| 0x17c  | 4~0 | 0x14    | pull-up driving resistance for B_DQ8~B_DQ15     |
| 0x0ac  | 7~5 | 0x4     | Falling edge slew rate control for A_DQ0~A_DQ7  |
|        | 4~2 | 0x4     | Rising edge slew rate control for A_DQ0~A_DQ7   |
| 0x0ec  | 7~5 | 0x4     | Falling edge slew rate control for A_DQ8~A_DQ15 |
|        | 4~2 | 0x4     | Rising edge slew rate control for A_DQ8~A_DQ15  |
| 0x12c  | 7~5 | 0x4     | Falling edge slew rate control for B_DQ0~B_DQ7  |
|        | 4~2 | 0x4     | Rising edge slew rate control for B_DQ0~B_DQ7   |
| 0x16c  | 7~5 | 0x4     | Falling edge slew rate control for B_DQ8~B_DQ15 |
|        | 4~2 | 0x4     | Rising edge slew rate control for B_DQ8~B_DQ15  |
| 0x084  | 4~0 | 0x4     | pull-down ODT resistance for A_DQ0~A_DQ7        |
| 0x0b8  | 4~0 | 0x4     | pull-up ODT resistance for A_DQ0~A_DQ7          |
| 0x0c4  | 4~0 | 0x4     | pull-down ODT resistance for A_DQ8~A_DQ15       |
| 0x0f8  | 4~0 | 0x4     | pull-up ODT resistance for A_DQ8~A_DQ15         |
| 0x104  | 4~0 | 0x4     | pull-down ODT resistance for B_DQ0~B_DQ7        |
| 0x138  | 4~0 | 0x4     | pull-up ODT resistance for B_DQ0~B_DQ7          |

|       |     |     |                                           |
|-------|-----|-----|-------------------------------------------|
| 0x144 | 4~0 | 0x4 | pull-down ODT resistance for B_DQ8~B_DQ15 |
| 0x178 | 4~0 | 0x4 | pull-up ODT resistance for B_DQ8~B_DQ15   |

The value is larger, the drive strength is stronger.

DDR3 1.5V DQ/DQS/CMD driver and ODT strength table

Table 2-7 DDR3 1.5V DQ/DQS/CMD Driver and ODT resistance

| Control bit  | 5'b00000 | 5'b00001 | 5'b00010 | 5'b00011 |
|--------------|----------|----------|----------|----------|
| Pull-up/down | +∞       | 451.6ohm | 225.8ohm | 150.5ohm |
| Control bit  | 5'b00100 | 5'b00101 | 5'b00110 | 5'b00111 |
| Pull-up/down | 112.9ohm | 90.3ohm  | 75.3ohm  | 64.5ohm  |
| Control bit  | 5'b01000 | 5'b01001 | 5'b01010 | 5'b01011 |
| Pull-up/down | 56.5ohm  | 50.2ohm  | 45.2ohm  | 41.1ohm  |
| Control bit  | 5'b01100 | 5'b01101 | 5'b01110 | 5'b01111 |
| Pull-up/down | 37.6ohm  | 34.7ohm  | 33.3ohm  | 30.1ohm  |
| Control bit  | 5'b10000 | 5'b10001 | 5'b10010 | 5'b10011 |
| Pull-up/down | 56.5ohm  | 50.2ohm  | 45.2ohm  | 41.1ohm  |
| Control bit  | 5'b10100 | 5'b10101 | 5'b10110 | 5'b10111 |
| Pull-up/down | 37.6ohm  | 34.7ohm  | 33.3ohm  | 30.1ohm  |
| Control bit  | 5'b11000 | 5'b11001 | 5'b11010 | 5'b11011 |
| Pull-up/down | 28.2ohm  | 26.6ohm  | 25.1ohm  | 23.8ohm  |
| Control bit  | 5'b11100 | 5'b11101 | 5'b11110 | 5'b11111 |
| Pull-up/down | 22.6ohm  | 21.5ohm  | 20.5ohm  | 19.6ohm  |

Table 2-8 DDR4/LPDDR2/3 1.2V DQ/DQS/CMD driver and ODT resistance

| Control bit  | 5'b00000 | 5'b00001 | 5'b00010 | 5'b00011 |
|--------------|----------|----------|----------|----------|
| Pull-up/down | +∞       | 480.4ohm | 240.2ohm | 160.1ohm |
| Control bit  | 5'b00100 | 5'b00101 | 5'b00110 | 5'b00111 |
| Pull-up/down | 120.1ohm | 96.1ohm  | 80.1ohm  | 68.6ohm  |
| Control bit  | 5'b01000 | 5'b01001 | 5'b01010 | 5'b01011 |
| Pull-up/down | 60.0ohm  | 53.4ohm  | 48.0ohm  | 43.7ohm  |
| Control bit  | 5'b01100 | 5'b01101 | 5'b01110 | 5'b01111 |
| Pull-up/down | 40.0ohm  | 37.0ohm  | 34.3ohm  | 32.0ohm  |
| Control bit  | 5'b10000 | 5'b10001 | 5'b10010 | 5'b10011 |
| Pull-up/down | 60.0ohm  | 53.4ohm  | 48.0ohm  | 43.7ohm  |
| Control bit  | 5'b10100 | 5'b10101 | 5'b10110 | 5'b10111 |
| Pull-up/down | 40.0ohm  | 37.0ohm  | 34.3ohm  | 32.0ohm  |
| Control bit  | 5'b11000 | 5'b11001 | 5'b11010 | 5'b11011 |
| Pull-up/down | 30.0ohm  | 28.3ohm  | 26.7ohm  | 25.3ohm  |
| Control bit  | 5'b11100 | 5'b11101 | 5'b11110 | 5'b11111 |
| Pull-up/down | 24.0ohm  | 22.9ohm  | 21.8ohm  | 20.9ohm  |

## 2.6.5 PHY Low Speed Mode (200MHz)

DDR PHY supports low speed to high speed DDR3 by using two operating mode: normal delay line mode up to 800Mbps or more, low power mode where we support any speed up to 533Mbps. If all TX DLLs are bypassed, the PHY will enter low power state.

The DDR PHY entries low power mode when setting DLLs into Bypass mode. The following table illustrates related register settings.

Table 2-9 Low Power DLL Setting

| <b>Offset</b> | <b>Bit</b> | <b>Default</b> | <b>Low power Setting</b> | <b>Description</b>                       |
|---------------|------------|----------------|--------------------------|------------------------------------------|
| 0x290         | 4          | 0x0            | 0x1                      | right channel B TX DQ DLL in bypass mode |
|               | 3          | 0x0            | 0x1                      | left channel B TX DQ DLL in bypass mode  |
|               | 2          | 0x0            | 0x1                      | right channel A TX DQ DLL in bypass mode |
|               | 1          | 0x0            | 0x1                      | left channel A TX DQ DLL in bypass mode  |
|               | 0          | 0x0            | 0x1                      | CMD/CK DLL in bypass mode                |
| 0x4c          | 4          | 0x0            | 0x1                      | CMD DLL phase select                     |
| 0x50          | 3          | 0x0            | 0x0                      | CK DLL phase select                      |
| 0x98          | 4          | 0x0            | 0x1                      | A_DQ0~A_DQ7 TX DLL phase select          |
| 0x9c          | 3          | 0x0            | 0x0                      | A_DQS0/A_DQSB0 TX DLL phase select       |
| 0xd8          | 4          | 0x0            | 0x1                      | A_DQ8~A_DQ15 TX DLL phase select         |
| 0xdc          | 3          | 0x0            | 0x0                      | A_DQS1/A_DQSB1 TX DLL phase select       |
| 0x118         | 4          | 0x1            | 0x1                      | B_DQ0~B_DQ7 TX DLL phase select          |
| 0x11c         | 3          | 0x0            | 0x0                      | B_DQS0/B_DQSB0 TX DLL phase select       |
| 0x158         | 4          | 0x1            | 0x1                      | B_DQ8~B_DQ15 TX DLL phase select         |
| 0x15c         | 3          | 0x0            | 0x0                      | B_DQS1/B_DQSB1 TX DLL phase select       |

## 2.6.6 Per bit de-skew tuning

Per-bit de-skew is designed for compensating PCB trace mismatch, DDR PHY support skew individually adjustable for all PHY signals. There are eight steps for each bit de-skew adjusting, and the adjust resolution under different corners is shown below:

Table 2-10 per-bit de-skew tuning resolution

|                    | <b>ff</b> | <b>tt</b> | <b>ss</b> |
|--------------------|-----------|-----------|-----------|
| de-skew resolution | 15ps      | 20ps      | 32ps      |

Pre-bit de-skew is realized with inverter chain delay, per-bit de-skew control signals select how much inverters are connected to data path, the minimum resolution is determined by the two inverters minimum delay.

TX path deskew and RX path deskew employ same delay line, and they have same deskev tuning resolution. Minimum RX deskew tuning resolution can be about 28ps with SMIC55II tt corner process, and we can re-design tuning resolution according to system and customer requirement.

## 2.6.7 DDR PHY Calibration

DDR PHY auto dqs calibration function has been implemented in the PHY. The entire training processes only need to configure the register to start and wait for finish.

The entire training process is as follows:

1. PHY's register is reset, the setup is complete.
2. Send the initial command to dram and complete dram initialization.
3. Set the PHY's register beginning calibration.

| <b>Offset</b> | <b>Bit</b> | <b>Default</b> | <b>Description</b>                                                                                               |
|---------------|------------|----------------|------------------------------------------------------------------------------------------------------------------|
| 0x8           | 5~4        | 0x0            | DQS gating calibration CS select signal<br>2'b00: select CS0 and CS1      2'b01: select CS1<br>2'b10: select CS0 |
|               | 1          | 0x0            | set calibration bypass mode(1:bypass mode; 0:nomal)                                                              |
|               | 0          | 0x0            | set calibration start (1: start; 0: stop)                                                                        |

4. Wait for the calibration finish by PHYREGFF.
5. Normal read and writes operation can begin.

## 2.6.8 DDR PHY Write Leveling Training

DDR PHY auto write leveling training function has been implemented in the PHY. The entire training processes only need to configure the register to start and wait for finish.

The entire training process is as follows:

1. PHY's register is reset, the setup is complete.

2. Send the initial command to dram and complete dram initialization.
3. Set the PHYREG05 and PHYREG06 to configure the dram mode register which used to enable dram write leveling training function.
4. Set the PHY's register to begin training.

| <b>Offset</b> | <b>Bit</b> | <b>Default</b> | <b>Description</b>                                                                                     |
|---------------|------------|----------------|--------------------------------------------------------------------------------------------------------|
| 0x8           | 7~6        | 0x0            | Write leveling CS select signal<br>2'b00: select CS0 and CS1    2'b01: select CS1<br>2'b10: select CS0 |
|               | 3          | 0x0            | Write leveling calibration bypass mode, active high                                                    |
|               | 2          | 0x0            | Write leveling calibration control, active high                                                        |

5. Wait for the calibration finish by PHYREGF0.
6. Normal read and writes operation can begin.

## Chapter 3 Mobile Storage Host Controller

### 3.1 Overview

The Mobile Storage Host Controller is designed to support Secure Digital memory (SD-max version 3.01) with 1 bits or 4 bits data width, Multimedia Card(MMC-max version 4.51) with 1 bits or 4 bits or 8 bits data width.

The Host Controller is instantiated for SDMMC, SDIO and EMMC. The interface difference between these instances is shown in "Interface Description".

The Host Controller supports following features:

- Bus Interface Features:
  - Support AMBA AHB interface for master and slave
  - Supports internal DMA interface(IDMAC)
    - ◆ Supports 16/32-bit data transfers
    - ◆ Single-channel; single engine used for Transmit and Receive, which are mutually exclusive
    - ◆ Dual-buffer and chained descriptor linked list
    - ◆ Each descriptor can transfer up to 4KB of data in chained mode and 8KB of data in dual-buffer mode
    - ◆ Programmable burst size for optimal host bus utilization
  - Support combined single FIFO for both transmit and receive operations
  - Support FIFO size of 256x32
  - Support FIFO over-run and under-run prevention by stopping card clock
- Card Interface Features:
  - Support Secure Digital memory protocol commands
  - Support Secure Digital I/O protocol commands
  - Support Multimedia Card protocol commands
  - Support Command Completion Signal and interrupts to host
  - Support CRC generation and error detection
  - Support programmable baud rate
  - Support power management and power switch
  - Support card detection
  - Support write protection
  - Support hardware reset
  - Support SDIO interrupts in 1-bit and 4-bit modes
  - Support 4-bit mode in SDIO3.0
  - Support SDIO suspend and resume operation
  - Support SDIO read wait
  - Support block size of 1 to 65,535 bytes
  - Support 1-bit, 4-bit and 8-bit SDR modes
  - Support boot in 1-bit, 4-bit and 8-bit SDR modes
  - Support Packed Commands, CMD21, CMD49
- Clock Interface Features:
  - Support 0/90/180/270-degree phase shift operation for sample clock (cclk\_in\_sample) and drive clock(cclk\_in\_drv) relative to function clock(cclk\_in) respectively
  - Support phase tuning using delay line for sample clock(cclk\_in\_sample) and drive clock(cclk\_in\_drv) relative to function clock (cclk\_in) respectively. The max number of delay element number is 256

### 3.2 Block Diagram

The Host Controller consists of the following main functional blocks.



Fig. 3-1 Host Controller Block Diagram

- Clock Generate Unit(CLKGEN): generates card interface clock **cclk\_in/** **cclk\_sample/cclk\_drv** based on **cclkin** and configuration information.
- Asynchronous dual-port memory(BUFFER): Uses a two-clock synchronous read and synchronous write dual-port RAM. One of the ports is connected to the host clock, and the second port is connected to the card clock.
- Bus Interface Unit (BIU): Provides AMBA AHB interfaces for register and data read/writes.
- Card Interface Unit (CIU): Takes care of the SD/MMC protocols and provides clock management.

### 3.3 Function Description

#### 3.3.1 Bus Interface Unit

The Bus Interface Unit provides the following functions:

- Host interface
- Interrupt control
- Register access
- External FIFO access
- Power control and card detection

##### 1. Host Interface Unit

The Host Interface Unit is an AHB slave interface, which provides the interface between the SD/MMC card and the host bus.

## 2. Register Unit

The register unit is part of the bus interface unit; it provides read and write access to the registers.

All registers reside in the Bus Interface Unit clock domain. When a command is sent to a card by setting the start\_bit, which is bit[31] of the SDMMC\_CMD register, all relevant registers needed for the CIU operation are transferred to the CIU block. During this time, the registers that are transferred from the BIU to the CIU should not be written. The software should wait for the hardware to clear the start bit before writing to these registers again. The register unit has a hardware locking feature to prevent illegal writes to registers. The lock is necessary in order to avoid metastability violations, both because the host and card clock domains are different and to prevent illegal software operations.

Once a command start is issued by setting the start\_bit of the SDMMC\_CMD register, the following registers cannot be reprogrammed until the command is accepted by the card interface unit:

- SDMMC\_CMD – Command
- SDMMC\_CMDARG – Command Argument
- SDMMC\_BYTCNT – Byte Count
- SDMMC\_BLKSIZ – Block Size
- SDMMC\_CLKDIV – Clock Divider
- SDMMC\_CLKENA – Clock Enable
- SDMMC\_CLKSRC – Clock Source
- SDMMC\_TMOUT – Timeout
- SDMMC\_CTYPE – Card Type

The hardware resets the start\_bit once the CIU accepts the command. If a host write to any of these registers is attempted during this locked time, then the write is ignored and the hardware lock error bit is set in the raw interrupt status register. Additionally, if the interrupt is enabled and not masked for a hardware lock error, then an interrupt is sent to the host.

When the Card Interface Unit is in an idle state, it typically takes the following number of clocks for the command handshake, where clk is the BIU clock and cclk\_in is the CIU clock: 3 (clk) + 3 (cclk\_in)

Once a command is accepted, you can send another command to the CIU—which has a one-deep command queue—under the following conditions:

- If the previous command was not a data transfer command, the new command is sent to the SD/MMC card once the previous command completes.
- If the previous command is a data transfer command and if wait\_prvdata\_complete (bit[13]) of the 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.

## 3. Interrupt Controller Unit

The interrupt controller unit generates an interrupt that depends on the controller raw interrupt status, the interrupt-mask register, and the global interrupt-enable register bit. Once an interrupt condition is detected, it sets the corresponding interrupt bit in the raw interrupt status register. 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 glitches.

The int\_enable is reset to 0 on power-on, and the interrupt mask bits are set to 32'h0, which masks all the interrupts.

*Notes:*

*Before enabling the interrupt, it is always recommended that you write 32'ffff\_ffff to the raw interrupt status register in order to clear any pending unserviced interrupts. When clearing interrupts during normal operation, ensure that you clear only the interrupt bits that you serviced.*

The SDIO Interrupts, Receive FIFO Data Request (RXDR), and Transmit FIFO Data Request (TXDR) are set by level-sensitive interrupt sources. Therefore, the interrupt source should be first cleared before you can clear the interrupt bit of the Raw Interrupt register. For example, on seeing the Receive FIFO Data Request (RXDR) interrupt, the FIFO should be emptied so that the "FIFO count greater than the RX-Watermark" condition, which triggers the interrupt, becomes inactive. The rest of the interrupts are triggered by a single clock-pulse-width source.

Table 3-1 Bits in Interrupt Status Register

| <b>Bits</b> | <b>Interrupt</b>                        | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------------|-----------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 24          | sdio_interrupt                          | Interrupt from SDIO card. In MMC-Ver3.3-only mode, these bits are always 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 16          | Card no-busy                            | If card exit busy status, the interrupt happened                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 15          | End Bit Error (read)/Write no CRC (EBE) | Error in end-bit during read operation, or no data CRC received during write operation.<br>For MMC CMD19, there may be no CRC status returned by the card. Hence, EBE is set for CMD19. The application should not treat this as an error.                                                                                                                                                                                                                                                                                                                                         |
| 14          | Auto Command Done (ACD)                 | Stop/abort commands automatically sent by card unit and not initiated by host; similar to Command Done (CD) interrupt.<br>Recommendation:<br>Software typically need not enable this for non CE-ATA accesses; Data Transfer Over (DTO) interrupt that comes after this interrupt determines whether data transfer has correctly completed.                                                                                                                                                                                                                                         |
| 13          | Start Bit Error (SBE)                   | Error in data start bit when data is read from a card. In 4-bit mode, if DAT[0] line indicates start bit—that is, 0—and any of the other data bits do not have start bit, then this error is set.<br>Busy Complete Interrupt when data is written to the card. This interrupt is generated after completion of busy driven by the card after the last data block is written into the card.                                                                                                                                                                                         |
| 12          | Hardware Locked write Error (HLE)       | During hardware-lock period, write attempted to one of locked registers.<br>When software sets the start_cmd bit in the SDMMC_CMD register, the Host Controller tries to load the command. If the command buffer is already filled with a command, this error is raised. The software then has to reload the command.                                                                                                                                                                                                                                                              |
| 11          | FIFO Underrun/ Overrun Error (FRUN)     | Host tried to push data when FIFO was full, or host tried to read data when FIFO was empty. Typically this should not happen, except due to error in software. Card unit never pushes data into FIFO when FIFO is full, and pop data when FIFO is empty.<br>If IDMAC is enabled, FIFO underrun/overrun can occur due to a programming error on MSIZE and watermark values in SDMMC_FIFOTH register.                                                                                                                                                                                |
| 10          | Data Starvation by Host Timeout (HTO)   | To avoid data loss, card clock out is stopped if FIFO is empty when writing to card, or FIFO is full when reading from card. Whenever card clock is stopped to avoid data loss, data-starvation timeout counter is started with data-timeout value. This interrupt is set if host does not fill data into FIFO during write to card, or does not read from FIFO during read from card before timeout period.<br>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, |

| <b>Bits</b> | <b>Interrupt</b>                  | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------------|-----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             |                                   | which automatically restarts cclk_out and card state machines.<br>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 (DRTO)          | In Normal functioning mode: Data read timeout (DRTO)<br>Data timeout occurred. Data Transfer Over (DTO) also set if data timeout occurs.<br>In Boot Mode: Boot Data Start (BDS)<br>When set, indicates that Host Controller has started to receive boot data from the card. A write to this register with a value of 1 clears this interrupt.                                                                                                                                    |
| 8           | Response Timeout (RTO)            | In normal functioning mode: Response timeout (RTO)<br>Response timeout occurred. Command Done (CD) also set if response timeout occurs. If command involves data transfer and when response times out, no data transfer is attempted by Host Controller.<br>In Boot Mode: Boot Ack Received (BAR)<br>When expect_boot_ack is set, on reception of a boot acknowledge pattern—0-1-0—this interrupt is asserted. A write to this register with a value of 1 clears this interrupt. |
| 7           | Data CRC Error (DCRC)             | Received Data CRC does not match with locally-generated CRC in CIU.<br>Can also occur if the Write CRC status is incorrectly sampled by the Host.                                                                                                                                                                                                                                                                                                                                |
| 6           | Response CRC Error (RCRC)         | Response CRC does not match with locally-generated CRC in CIU.                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 5           | Receive FIFO Data Request (RXDR)  | Interrupt set during read operation from card when FIFO level is greater than Receive-Threshold level.<br>Recommendation:<br>In DMA modes, this interrupt should not be enabled.<br>In non-DMA mode: pop RX_WMark + 1 data from FIFO.                                                                                                                                                                                                                                            |
| 4           | Transmit FIFO Data Request (TXDR) | Interrupt set during write operation to card when FIFO level reaches less than or equal to Transmit-Threshold level.<br>Recommendation:<br>In DMA modes, this interrupt should not be enabled.<br>In non-DMA mode:<br><pre>if (pending_bytes &gt; (FIFO_DEPTH - TX_WMark))     push (FIFO_DEPTH - TX_WMark) data into FIFO else     push pending_bytes data into FIFO</pre>                                                                                                      |
| 3           | Data Transfer Over (DTO)          | Indicates Data transfer completed. Though on detection of errors-Start Bit Error, Data CRC error, and so on, DTO may or may not be set; the application must issue CMD12, which ensures that DTO is set.<br>Recommendation:<br>In non-DMA mode, when data is read from card, on seeing interrupt, host should read any pending data from FIFO. In DMA mode, DMA controllers guarantee FIFO is flushed before interrupt.                                                          |

| Bits | Interrupt           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                     | DTO bit is set at the end of the last data block, even if the device asserts MMC busy after the last data block.                                                                                                                                                                                                                                                                                                                                                                                                            |
| 2    | Command Done(CD)    | Command sent to card and got response from card, even if Response Error or CRC error occurs.                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 1    | Response Error (RE) | Error in received response set if one of following occurs: <ul style="list-style-type: none"> <li>● Transmission bit != 0</li> <li>● Command index mismatch</li> <li>● End-bit != 1</li> </ul>                                                                                                                                                                                                                                                                                                                              |
| 0    | Card-Detect (CDT)   | When one or more cards inserted or removed, this interrupt occurs.<br>Software should read card-detect register to determine current card status.<br>Recommendation: After power-on and before enabling interrupts, software should read card detect register and store it in memory. When interrupt occurs, it should read card detect register and compare it with value stored in memory to determine which card(s) were removed/inserted. Before exiting ISR, software should update memory with new card-detect value. |

#### 4. FIFO Controller Unit

The FIFO controller interfaces the external FIFO to the host interface and the card controller unit. When FIFO overrun and under-run conditions occur, the card clock stops in order to avoid data loss.

The FIFO uses a two-clock synchronous read and synchronous write dual-port RAM. One of the ports is connected to the host clock, clk, and the second port is connected to the card clock, cclk\_in.

*Notes: The FIFO controller does not support simultaneous read/write access from the same port. For debugging purposes, the software may try to write into the FIFO and read back the data; results are indeterminate, since the design does not support read/write access from the same port.*

#### 5. Power Control and Card Detection Unit

The register unit has registers that control the power. Power to each card can be selectively turned on or off.

The card detection unit looks for any changes in the card-detect signals for card insertion or card removal. It filters out the 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. 3-2 SD/MMC Card-Detect Signal

#### 6. DMA Interface Unit

DMA signals interface the 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 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/write to access the data FIFO.

### **3.3.2 Card Interface Unit**

The Card Interface Unit (CIU) interfaces with the Bus Interface Unit (BIU) and the devices. The host writes command parameters to the BIU control registers, and these parameters are then passed to the CIU. Depending on control register values, the CIU generates SD/MMC command and data traffic on a selected card bus according to SD/MMC protocol. The Host Controller accordingly controls the command and data path.

The following software restrictions should be met for proper CIU operation:

- Only one data transfer command can be issued at a time.
- During an open-ended card write operation, if the card clock is stopped because the FIFO is empty, the software must first fill the data into the FIFO and start the card clock. It can then issue only a stop/abort command to the card.
- When issuing card reset commands (CMD0, CMD15 or CMD52\_reset) while a card data transfer is in progress, the software must set the stop\_abort\_cmd bit in the Command register so that the Host Controller can stop the data transfer after issuing the card reset command.
- When the data end bit error is set in the SDMMC\_RINTSTS register, the Host Controller does not guarantee SDIO interrupts. The software should ignore the SDIO interrupts and issue the stop/abort command to the card, so that the card stops sending the read data.
- If the card clock is stopped because the FIFO is full during a card read, the software should read at least two FIFO locations to start the card clock.

The CIU block consists of the following primary functional blocks:

- Command path
- Data path
- SDIO interrupt control
- Clock control
- 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 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 device. The command path loads this new command (command, command argument, timeout) and sends acknowledge to the BIU by asserting cmd\_taken.

Once the new command is loaded, the command path state machine sends a command to the device bus-including the internally generated CRC7-and receives a response, if any. The state machine then sends the received response and signals to the BIU that the command is done, and then waits for eight clocks before loading a new command.

#### **Load Command Parameters**

One of the following commands or responses is loaded in the command path:

- New command from BIU – When start\_cmd is asserted, then the start\_cmd bit is set in the 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 irq response” request is signaled by the BIU, then the send\_irq\_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 = 0).
  - After completion of the current data transfer, if a predefined data transfer is in progress.

### Send Command and Receive Response

Once a new command is loaded in the command path, update\_clock\_registers\_only bit is unset – the command path state machine sends out a command on the device bus; the command path state machine is illustrated in following figure.



Fig. 3-3 Host Controller Command Path State Machine

The command path state machine performs the following functions, according to Command register bit values:

- send\_initialization – Initialization sequence of 80 clocks is sent before sending the command.
- response\_expected – Response is expected for the command. After the command is sent out, the command path state machine receives a 48-bit or 136-bit response and sends it to the BIU. If the start bit of the card response is not received within the number of clocks programmed in the timeout register, then the response timeout and command done bit is set in the Raw Interrupt Status register as a signal to the BIU. If the response-expected bit is not set, the command path sends out a command and signals a response done to the BIU; that is, the command done bit is set in the Raw Interrupt Status register.
- response\_length – If this bit is set, a 136-bit response is received; if it is not set, a 48-bit response is received.
- check\_response\_crc – If this bit is set, the command path compares CRC7 received in the response with the internally-generated CRC7. If the two do not match, the response CRC error is signaled to the BIU; that is, the response CRC error bit is set in the Raw Interrupt Status register.

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

## **Polling Command Completion Signal**

The device generates the Command Completion Signal in order to notify the host controller of the normal command completion or command termination.

## **Command Completion Signal Detection and Interrupt to Host Processor**

If the ccs\_expected bit is set in the Command register, the Command Completion Signal (CCS) from the device is indicated by setting the Data Transfer Over (DTO) bit in the SDMMC\_RINTSTS register. The Host Controller generates a Data Transfer Over (DTO) interrupt if this interrupt is not masked.

## **Command Completion Signal Timeout**

If the command expects a CCS from the device—if the ccs\_expected bit is set in the Command register—the command state machine waits for the CCS and remains in a wait\_CCS state. If the device fails to send out the CCS, the host software should implement a timeout mechanism to free the command and data path. The host controller does not implement a hardware timer; it is the responsibility of the host software to maintain a software timer.

In the event of a CCS timeout, the host should issue a CCSD by setting the send\_ccsd bit in the CTRL register. The host controller command state machine sends the CCSD to the device and exits to an idle state. After sending the CCSD, the host should also send a CMD12 to the device in order to abort the outstanding command.

## **Send Command Completion Signal Disable**

If the send\_ccsd bit is set in the CTRL register, the host sends a Command Completion Signal Disable (CCSD) pattern on the CMD line. The host can send the CCSD while waiting for the CCS or after a CCS timeout happens.

After sending the CCSD pattern, the host sets the Command Done (CD) bit in SDMMC\_RINTSTS and also generates an interrupt to the host if the Command Done interrupt is not masked.

## **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 following figure, starts data transmission two clocks after a response for the data write command is received; this occurs even if the command path detects a response error or response CRC error. If a response is not received from the card because of a response timeout, data is not transmitted. Depending upon the value of the transfer\_mode bit in the Command register, the data transmit state machine puts data on the card data bus in a stream or in block(s).



Fig. 3-4 Host Controller 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 SDMMC\_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 SDMMC\_RINTSTS register.

If a negative CRC status is received from the card, the data path signals a data CRC error to the BIU by setting the data CRC error bit in the SDMMC\_RINTSTS register.

Additionally, if the start bit of the CRC status is not received by two clocks after the end of the data block, a CRC status start bit error is signaled to the BIU by setting the write-no-CRC bit in the SDMMC\_RINTSTS register.

### Multiple Block Data

A multiple-block write-data transfer occurs if the transfer\_mode bit in the 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 SDMMC\_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 SDMMC\_RINTSTS register.

If the remaining data bytes are greater than 0, the data path state machine starts to transmit another data block.

If a negative CRC status is received from the card, the data path signals a data CRC error to the BIU by setting the data CRC error bit in the SDMMC\_RINTSTS register, and continues further data transmission until all the bytes are transmitted.

Additionally, if the CRC status start bit is not received by two clocks after the end of a data block, a CRC status start bit error is signaled to the BIU by setting the write-no-CRC bit in the SDMMC\_RINTSTS register; further data transfer is terminated.

If the send\_auto\_stop bit is set in the 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 following figure, receives data two clock cycles after the end bit of a data read command, even if the command path detects a response error or response CRC error. If a response is not received from the card because a response timeout occurs, the BIU does not receive a signal that the data transfer is complete; this happens if the command sent by the Host Controller is an illegal operation for the card, which keeps the card from starting a read data transfer.

If data is not received before the data timeout, the data path signals a data timeout to the BIU and an end to the data transfer done. Based on the value of the transfer\_mode bit in the Command register, the data-receive state machine gets data from the card data bus in a stream or block(s).



Fig. 3-5 Host Controller 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 SDMMC\_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 SDMMC\_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 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 software should set the send\_auto\_stop bit according to details listed in following table.  
Table 3-2 Auto-Stop Generation

| Card type | Transfer type        | Byte Count | send_auto_stop bit set | Comments                           |
|-----------|----------------------|------------|------------------------|------------------------------------|
| MMC       | Stream read          | 0          | No                     | Open-ended stream                  |
| MMC       | Stream read          | >0         | Yes                    | Auto-stop after all bytes transfer |
| MMC       | Stream write         | 0          | No                     | Open-ended stream                  |
| MMC       | Stream write         | >0         | Yes                    | Auto-stop after all bytes transfer |
| MMC       | Single-block read    | >0         | No                     | Byte count =0 is illegal           |
| MMC       | Single-block write   | >0         | No                     | Byte count =0 is illegal           |
| MMC       | Multiple-block read  | 0          | No                     | Open-ended multiple block          |
| MMC       | Multiple-block read  | >0         | Yes①                   | Pre-defined multiple block         |
| MMC       | Multiple-block write | 0          | No                     | Open-ended multiple block          |
| MMC       | Multiple-block write | >0         | Yes①                   | 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       | 0          | No                     | Open-ended multiple block          |

| Card type | Transfer type        | Byte Count | send_auto_stop bit set | Comments                   |
|-----------|----------------------|------------|------------------------|----------------------------|
|           | write                |            |                        |                            |
| 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 Host Controller generates an internal stop command and loads it into the command path so that the end bit of the stop command is sent out when the last byte of data is read from the card and no extra data byte is received. If the byte count is less than 6 (48 bits), a few extra data bytes are received from the card before the end bit of the stop command is sent.
- Stream write for MMC card with byte count greater than 0 - The Host Controller generates an internal stop command and loads it into the command path so that the end bit of the stop command is sent when the last byte of data is transmitted on the card bus and no extra data byte is transmitted. If the byte count is less than 6 (48 bits), the data path transmits the data last in order to meet the above condition.
- Multiple-block read memory for SD card with byte count greater than 0 – If the block size is less than 4 (single-bit data bus), 16 (4-bit data bus), or 32 (8-bit data bus), the auto-stop command is loaded in the command path after all the bytes are read. Otherwise, the top command is loaded in the command path so that the end bit of the stop command is sent after the last data block is received.
- Multiple-block write memory for SD card with byte count greater than 0 – If the block size is less than 3 (single-bit data bus), 12 (4-bit data bus), or 24 (8-bit data bus), the auto-stop command is loaded in the command path after all data blocks are transmitted. Otherwise, the stop command is loaded in the command path so that the end bit of the stop command is sent after the end bit of the CRC status is received.
- Precaution for host software during auto-stop – Whenever an auto-stop command is issued, the host software should not issue a new command to the SD/MMC device until the auto-stop is sent by the Host Controller and the data transfer is complete. If the host issues a new command during a data transfer with the auto-stop in progress, an auto-stop command may be sent after the new command is sent and its response is received; this can delay sending the stop command, which transfers extra data bytes. For a stream write, extra data bytes are erroneous data that can corrupt the card data. If the host wants to terminate the data transfer before the data transfer is complete, it can issue a stop or abort command, in which case the Host Controller does not generate an auto-stop command.

### 3. Non-Data Transfer Commands that Use Data Path

Some non-data transfer commands (non-read/write commands) also use the data path. Following table lists the commands and register programming requirements for them.

Table 3-3 Non-data Transfer Commands and Requirements

| Base Address [12:8]                 | CMD 27 | CMD 30 | CMD 42 | ACMD 13 | ACMD 22 | ACMD 51 |
|-------------------------------------|--------|--------|--------|---------|---------|---------|
| <b>Command register programming</b> |        |        |        |         |         |         |
| cmd_index                           | 6'h1B  | 6'h1E  | 6'h2A  | 6'h0D   | 6'h16   | 6'h33   |
| response_expect                     | 1      | 1      | 1      | 1       | 1       | 1       |
| rResponse_length                    | 0      | 0      | 0      | 0       | 0       | 0       |
| check_response_crc                  | 1      | 1      | 1      | 1       | 1       | 1       |
| data_expected                       | 1      | 1      | 1      | 1       | 1       | 1       |

| <b>Base Address<br/>[12:8]</b>               | <b>CMD<br/>27</b> | <b>CMD<br/>30</b>                 | <b>CMD<br/>42</b> | <b>ACMD<br/>13</b> | <b>ACMD<br/>22</b> | <b>ACMD<br/>51</b> |
|----------------------------------------------|-------------------|-----------------------------------|-------------------|--------------------|--------------------|--------------------|
| read/write                                   | 1                 | 0                                 | 1                 | 0                  | 0                  | 0                  |
| transfer_mode                                | 0                 | 0                                 | 0                 | 0                  | 0                  | 0                  |
| send_auto_stop                               | 0                 | 0                                 | 0                 | 0                  | 0                  | 0                  |
| wait_prevdata_complete                       | 0                 | 0                                 | 0                 | 0                  | 0                  | 0                  |
| stop_abort_cmd                               | 0                 | 0                                 | 0                 | 0                  | 0                  | 0                  |
| <b>Command Argument register programming</b> |                   |                                   |                   |                    |                    |                    |
|                                              | stuff bits        | 32-bit write protect data address | stuff bits        | stuff bits         | stuff bits         | stuff bits         |
| <b>Block Size register programming</b>       |                   |                                   |                   |                    |                    |                    |
|                                              | 16                | 4                                 | Num_bytes①        | 64                 | 4                  | 8                  |
| <b>Byte Count register programming</b>       |                   |                                   |                   |                    |                    |                    |
|                                              | 16                | 4                                 | Num_bytes①        | 64                 | 4                  | 8                  |

①: Num\_bytes = No. of bytes specified as per the lock card data structure (Refer to the SD specification and the MMC specification)

#### 4. SDIO Interrupt Control

Interrupts for SD cards are reported to the BIU by asserting an interrupt signal for two clock cycles. SDIO cards signal an interrupt by asserting cdata\_in low during the interrupt period; an interrupt period for the selected card is determined by the interrupt control state machine. An interrupt period is always valid for non-active or non-selected cards, and 1-bit data mode for the selected card. An interrupt period for a wide-bus active or selected card is valid for the following conditions:

- Card is idle
  - Non-data transfer command in progress
  - Third clock after end bit of data block between two data blocks
  - From two clocks after end bit of last data until end bit of next data transfer command
- Bear in mind that, in the following situations, the controller does not sample the SDIO interrupt of the selected card when the card data width is 4 bits. Since the SDIO interrupt is level-triggered, it is sampled in a further interrupt period and the host does not lose any SDIO interrupt from the card.
- Read/Write Resume – The CIU treats the resume command as a normal data transfer command. SDIO interrupts during the resume command are handled similarly to other data commands. According to the SDIO specification, for the normal data command the interrupt period ends after the command end bit of the data command; for the resume command, it ends after the response end bit. In the case of the resume command, the Controller stops the interrupt sampling period after the resume command end bit, instead of stopping after the response end bit of the resume command.
  - Suspend during read transfer – If the read data transfer is suspended by the host, the host sets the abort\_read\_data bit in the controller to reset the data state machine. In the CIU, the SDIO interrupts are handled such that the interrupt sampling starts after the abort\_read\_data bit is set by the host. In this case the controller does not sample SDIO interrupts between the period from response of the suspend command to setting the abort\_read\_data bit, and starts sampling after setting the abort\_read\_data bit.

#### 5. Clock Control

The clock control block provides different clock frequencies required for SD/MMC cards. The cclk\_in signal is the source clock ( $cclk_{in} \geq$  card max operating frequency) for clock divider of the clock control block. This source clock (cclk\_in) is used to generate different card clock frequencies (cclk\_out). The card clock can have different clock frequencies, since the card can be a low-speed card or a full-speed card. The Host Controller provides one clock signal (cclk\_out).

The clock frequency of a card depends on the following clock control registers:

- Clock Divider register – Internal clock dividers are used to generate different clock frequencies required for card. The division factor for each clock divider can be programmed by writing to the Clock Divider register. 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 – cclk\_out can be enabled or disabled for each card under the following conditions:
  - clk\_enable – cclk\_out for a card is enabled if the clk\_enable bit for a card in the Clock Control register is programmed (set to 1) or disabled (set to 0).
  - Low-power mode – Low-power mode of a card can be enabled by setting the low-power mode bit of the Clock Control register to 1. If low-power mode is enabled to save card power, the cclk\_out is disabled when the card is idle for at least 8 card clock cycles. It is enabled when a new command is loaded and the command path goes to a non-idle state.

Additionally, cclk\_out is disabled when an internal FIFO is full – card read (no more data can be received from card) – or when the FIFO is empty – card write (no data is available for transmission). This helps to avoid FIFO overrun and underrun conditions. It is used by the command and data path to qualify cclk\_in for driving outputs and sampling inputs at the programmed clock frequency for the selected card, according to the Clock Divider and Clock Source register values.

Under the following conditions, the card clock is stopped or disabled, along with the active clk\_en, for the selected card:

- Clock can be disabled by writing to Clock Enable register (clk\_en bit = 1).
- If low-power mode is selected and card is idle, or not selected for 8 clocks.
- FIFO is full and data path cannot accept more data from the card and data transfer is incomplete –to avoid FIFO overrun.
- FIFO is empty and data path cannot transmit more data to the card and data transfer is incomplete – to avoid FIFO underrun.

## **6. Error Detection**

- Response
  - Response timeout – Response expected with response start bit is not received within programmed number of clocks in timeout register.
  - Response CRC error – Response is expected and check response CRC requested; response CRC7 does not match with the internally-generated CRC7.
  - Response error – Response transmission bit is not 0, command index does not match with the command index of the send command, or response end bit is not 1.
- Data transmit
  - No CRC status – During a write data transfer, if the CRC status start bit is not received two clocks after the end bit of the data block is sent out, the data path does the following:
    - ◆ Signals no CRC status error to the BIU
    - ◆ Terminates further data transfer
    - ◆ Signals data transfer done to the BIU
  - Negative CRC – If the CRC status received after the write data block is negative (that is, not 010), a data CRC error is signaled to the BIU and further data transfer is continued.
  - Data starvation due to empty FIFO – If the FIFO becomes empty during a write data transmission, or if the card clock is stopped and the FIFO remains empty for data timeout clocks, then a data-starvation error is signaled to the BIU and the data path continues to wait for data in the FIFO.
- Data receive
  - Data timeout – During a read-data transfer, if the data start bit is not received before the number of clocks that were programmed in the timeout register, the data path does the following:
    - ◆ Signals data-timeout error to the BIU
    - ◆ Terminates further data transfer

- ◆ Signals data transfer done to BIU
- Data start bit error – During a 4-bit or 8-bit read-data transfer, if the all-bit data line does not have a start bit, the data path signals a data start bit error to the BIU and waits for a data timeout, after which it signals that the data transfer is done.
- Data CRC error – During a read-data-block transfer, if the CRC16 received does not match with the internally generated CRC16, the data path signals a data CRC error to the BIU and continues further data transfer.
- Data end-bit error – During a read-data transfer, if the end bit of the received data is not 1, the data path signals an end-bit error to the BIU, terminates further data transfer, and signals to the BIU that the data transfer is done.
- Data starvation due to FIFO full – During a read data transmission and when the FIFO becomes full, the card clock is stopped. If the FIFO remains full for data timeout clocks, a data starvation error is signaled to the BIU (Data Starvation by Host Timeout bit is set in SDMMC\_RINTSTS register) and the data path continues to wait for the FIFO to start to empty.

### 3.3.3 Internal Direct Memory Access Controller (IDMAC)

The Internal Direct Memory Access Controller (IDMAC) has a Control and Status Register (CSR) and a single Transmit/Receive engine, which transfers data from host memory to the device port and vice versa. The controller utilizes a descriptor to efficiently move data from source to destination with minimal Host CPU intervention. You can program the controller to interrupt the Host CPU in situations such as data Transmit and Receive transfer completion from the card, as well as other normal or error conditions.

The IDMAC and the Host driver communicate through a single data structure. CSR addresses 0x80 to 0x98 are reserved for host programming.

The IDMAC transfers the data received from the card to the Data Buffer in the Host memory, and it transfers Transmit data from the Data Buffer in the Host memory to the FIFO.

Descriptors that reside in the Host memory act as pointers to these buffers.

A data buffer resides in physical memory space of the Host and consists of complete data or partial data. Buffers contain only data, while buffer status is maintained in the descriptor. Data chaining refers to data that spans multiple data buffers. However, a single descriptor cannot span multiple data.

A single descriptor is used for both reception and transmission. The base address of the list is written into Descriptor List Base Address Register (SDMMC\_DBADDR @0x88). A descriptor list is forward linked. The Last Descriptor can point back to the first entry in order to create a ring structure. The descriptor list resides in the physical memory address space of the Host. Each descriptor can point to a maximum of two data buffers.

#### 1. IDMAC CSR Access

When an IDMAC is introduced, an additional CSR space resides in the IDMAC that controls the IDMAC functionality. The host accesses the new CSR space in addition to the existing control register set in the BIU. The IDMAC CSR primarily contains descriptor information. For a write operation to the CSR, the respective CSR logic of the IDMAC and BIU decodes the address before accepting. For a read operation from the CSR, the appropriate CSR read path is enabled.

You can enable or disable the IDMAC operation by programming bit[25] in the SDMMC\_CTRL register of the BIU. This allows the data transfer by accessing the slave interface on the AMBA bus if the IDMAC is present but disabled. When IDMAC is enabled, the FIFO cannot be accessed through the slave interface.

#### 2. Descriptors

- Descriptor structures

The IDMAC uses these types of descriptor structures:

- Dual-Buffer Structure – The distance between two descriptors is determined by the Skip Length value programmed in the Descriptor Skip Length (DSL) field of the Bus Mode Register (SDMMC\_BMOD @0x80).



Fig. 3-6 Dual-Buffer Descriptor Structure

- Chain Structure – Each descriptor points to a unique buffer and the next descriptor.



Fig. 3-7 Chain Descriptor Structure

- Descriptor formats

Following figure illustrates the internal formats of a descriptor. The descriptor addresses must be aligned to the bus width used for 32-bit AHB data buses. Each descriptor contains 16 bytes of control and status information. DES0 is a notation used to denote the [31:0] bits, DES1 to denote [63:32] bits, DES2 to denote [95:64] bits, DES3 to denote [127:96] bits.



Fig. 3-8 Descriptor Formats for 32-bit AHB Address Bus Width

- The DES0 element in the IDMAC contains control and status information.

Table 3-4 Bits in IDMAC DES0 Element

| Bit | Name       | Description                                                                                                                                                                                                                 |
|-----|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31  | OWN        | When set, this bit indicates that the descriptor is owned by the IDMAC.<br>When this bit is reset, it indicates that the descriptor is owned by the Host.<br>The IDMAC clears this bit when it completes the data transfer. |
| 30  | Card Error | These error bits indicate the status of the transaction to or                                                                                                                                                               |

| Bit  | Name                                  | Description                                                                                                                                                                                                                                                                                                                                                                                  |
|------|---------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | Summary (CES)                         | from the card.<br>These bits are also present in SDMMC_RINTSTS Indicates the logical OR of the following bits: <ul style="list-style-type: none"> <li>● EBE: End Bit Error</li> <li>● RTO: Response Time out</li> <li>● RCRC: Response CRC</li> <li>● SBE: Start Bit Error</li> <li>● DRTO: Data Read Timeout</li> <li>● DCRC: Data CRC for Receive</li> <li>● RE: Response Error</li> </ul> |
| 29:6 | Reserved                              | -                                                                                                                                                                                                                                                                                                                                                                                            |
| 5    | End of Ring (ER)                      | When set, this bit indicates that the descriptor list reached its final descriptor. The IDMAC returns to the base address of the list, creating a Descriptor Ring. This is meaningful for only a dual-buffer descriptor structure.                                                                                                                                                           |
| 4    | Second Address Chained (CH)           | When set, this bit indicates that the second address in the descriptor is the Next Descriptor address rather than the second buffer address. When this bit is set, BS2 (DES1[25:13]) should be all zeros.                                                                                                                                                                                    |
| 3    | First Descriptor (FS)                 | When set, this bit indicates that this descriptor contains the first buffer of the data. If the size of the first buffer is 0, next Descriptor contains the beginning of the data.                                                                                                                                                                                                           |
| 2    | Last Descriptor (LD)                  | This bit is associated with the last block of a DMA transfer. When set, the bit indicates that the buffers pointed to by this descriptor are the last buffers of the data. After this descriptor is completed, the remaining byte count is 0. In other words, after the descriptor with the LD bit set is completed, the remaining byte count should be 0.                                   |
| 1    | Disable Interrupt on Completion (DIC) | When set, this bit will prevent the setting of the TI/RI bit of the IDMAC Status Register (IDSTS) for the data that ends in the buffer pointed to by this descriptor.                                                                                                                                                                                                                        |
| 0    | Reserved                              | -                                                                                                                                                                                                                                                                                                                                                                                            |

- The DES1 element contains the buffer size.

Table 3-5 Bits in IDMAC DES1 Element

| Bit   | Name                | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:26 | Reserved            | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 25:13 | Buffer 2 Size (BS2) | These bits indicate the second data buffer byte size. The buffer size must be a multiple of 2, 4, or 8, depending upon the bus widths—16, 32, and 64 respectively. In the case where the buffer size is not a multiple of 2, 4, or 8, the resulting behavior is undefined. If this field is 0, the DMA ignores this buffer and proceeds to the next buffer in case of a dual-buffer structure.<br>This field is not valid for chain structure; that is, if DES0[4] is set. |
| 12:0  | Buffer 1 Size (BS1) | Indicates the data buffer byte size, which must be a multiple of 2, 4, or 8 bytes, depending upon the bus widths—16, 32, and 64, respectively. In the case where the buffer size is not a multiple of 2, 4, or 8, the resulting behavior is undefined. This field should not be zero.<br>Note: If there is only one buffer to be programmed, you need to use only the Buffer 1, and not Buffer 2.                                                                          |

- The DES2 element contains the address pointer to the data buffer.

Table 3-6 Bits in IDMAC DES2 Element

| Bit   | Name                | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:26 | Reserved            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 25:13 | Buffer 2 Size (BS2) | <p>These bits indicate the second data buffer byte size. The buffer size must be a multiple of 2, 4, or 8, depending upon the bus widths—16, 32, and 64 respectively. In the case where the buffer size is not a multiple of 2, 4, or 8, the resulting behavior is undefined. If this field is 0, the DMA ignores this buffer and proceeds to the next buffer in case of a dual-buffer structure.</p> <p>This field is not valid for chain structure; that is, if DES0[4] is set.</p> |
| 12:0  | Buffer 1 Size (BS1) | <p>Indicates the data buffer byte size, which must be a multiple of 2, 4, or 8 bytes, depending upon the bus widths—16, 32, and 64, respectively. In the case where the buffer size is not a multiple of 2, 4, or 8, the resulting behavior is undefined. This field should not be zero.</p> <p>Note: If there is only one buffer to be programmed, you need to use only the Buffer 1, and not Buffer 2.</p>                                                                          |

- The DES3 element contains the address pointer to the next descriptor if the present descriptor is not the last descriptor in a chained descriptor structure or the second buffer address for a dual-buffer structure.

Table 3-7 Bits in IDMAC DES3 Element

| Bit  | Name                                                     | Description                                                                                                                                                                                                                                                                                                                                                                         |
|------|----------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | Buffer Address Pointer 2/ Next Descriptor Address (BAP2) | <p>These bits indicate the physical address of the second buffer when the dual-buffer structure is used. If the Second Address Chained (DES0[4]) bit is set, then this address contains the pointer to the physical memory where the Next Descriptor is present.</p> <p>If this is not the last descriptor, then the Next Descriptor address pointer must be bus-width aligned.</p> |

### 3. Initialization

IDMAC initialization occurs as follows:

- Write to IDMAC Bus Mode Register—SDMMC\_BMOD to set Host bus access parameters.
- Write to IDMAC Interrupt Enable Register—SDMMC\_IDINTEN to mask unnecessary interrupt causes.
- The software driver creates either the Transmit or the Receive descriptor list. Then it writes to IDMAC Descriptor List Base Address Register (SDMMC\_DBADDR), providing the IDMAC with the starting address of the list.
- The IDMAC engine attempts to acquire descriptors from the descriptor lists.

- Host Bus Burst Access

The IDMAC attempts to execute fixed-length burst transfers on the AHB Master interface if configured using the FB bit of the IDMAC Bus Mode register. The maximum burst length is indicated and limited by the PBL field. The descriptors are always accessed in the maximum possible burst-size for the 16-bytes to be read— 16\*8/bus-width.

The IDMAC initiates a data transfer only when sufficient space to accommodate the configured burst is available in the FIFO or the number of bytes to the end of data, when less than the configured burst-length.

The IDMAC indicates the start address and the number of transfers required to the AHB Master Interface. When the AHB Interface is configured for fixed-length bursts, then it transfers data using the best combination of INCR4/8/16 and SINGLE transactions.

Otherwise, in no fixed-length bursts, it transfers data using INCR (undefined length) and SINGLE transactions.

- Host Data Buffer Alignment

The Transmit and Receive data buffers in host memory must be aligned, depending on the data width.

- Buffer Size Calculations

The driver knows the amount of data to transmit or receive. For transmitting to the card, the IDMAC transfers the exact number of bytes to the FIFO, indicated by the buffer size field of DES1.

If a descriptor is not marked as last-LS bit of DES0-then the corresponding buffer(s) of the descriptor are full, and the amount of valid data in a buffer is accurately indicated by its buffer size field. If a descriptor is marked as last, then the buffer cannot be full, as indicated by the buffer size in DES1. The driver is aware of the number of locations that are valid in this case.

- Transmission

IDMAC transmission occurs as follows:

- 1) The Host sets up the elements (DES0-DES3) for transmission and sets the OWN bit (DES0[31]). The Host also prepares the data buffer.
- 2) The Host programs the write data command in the SDMMC\_CMD register in BIU.
- 3) The Host will also program the required transmit threshold level (TX\_WMark field in SDMMC\_FIFOTH register).
- 4) The IDMAC determines that a write data transfer needs to be done as a consequence of step 2.
- 5) The IDMAC engine fetches the descriptor and checks the OWN bit. If the OWN bit is not set, it means that the host owns the descriptor. In this case the IDMAC enters suspend state and asserts the Descriptor Unable interrupt in the SDMMC\_IDSTS register. In such a case, the host needs to release the IDMAC by writing any value to the poll demand register.
- 6) It will then wait for Command Done (CD) bit and no errors from BIU which indicates that a transfer can be done.
- 7) The IDMAC engine will now wait for a DMA interface request from BIU. This request will be generated based on the programmed transmit threshold value. For the last bytes of data which can't be accessed using a burst, SINGLE transfers are performed on AHB Master Interface.
- 8) The IDMAC fetches the Transmit data from the data buffer in the Host memory and transfers to the FIFO for transmission to card.
- 9) When data spans across multiple descriptors, the IDMAC will fetch the next descriptor and continue with its operation with the next descriptor. The Last Descriptor bit in the descriptor indicates whether the data spans multiple descriptors or not.
- 10) When data transmission is complete, status information is updated in SDMMC\_IDSTS register by setting Transmit Interrupt, if enabled. Also, the OWN bit is cleared by the IDMAC by performing a write transaction to DES0.

- Reception

IDMAC reception occurs as follows:

- 1) The Host sets up the element (DES0-DES3) for reception, sets the OWN (DES0[31]).
- 2) The Host programs the read data command in the SDMMC\_CMD register in BIU.
- 3) The Host will program the required receive threshold level (RX\_WMark field in FIFOTH register).
- 4) The IDMAC determines that a read data transfer needs to be done as a consequence of step 2.
- 5) The IDMAC engine fetches the descriptor and checks the OWN bit. If the OWN bit is not set, it means that the host owns the descriptor. In this case the DMA enters suspend state and asserts the Descriptor Unable interrupt in the SDMMC\_IDSTS register. In such a case, the host needs to release the IDMAC by writing any value to the poll demand register.
- 6) It will then wait for Command Done (CD) bit and no errors from BIU which indicates that a transfer can be done.
- 7) The IDMAC engine will now wait for a DMA interface request from BIU. This request will be generated based on the programmed receive threshold value. For the last bytes of data which can't be accessed using a burst, SINGLE transfers are performed on AHB.
- 8) The IDMAC fetches the data from the FIFO and transfer to Host memory.
- 9) When data spans across multiple descriptors, the IDMAC will fetch the next descriptor and continue with its operation with the next descriptor. The Last Descriptor bit in the

descriptor indicates whether the data spans multiple descriptors or not.

- 10) When data reception is complete, status information is updated in SDMMC\_IDSTS register by setting Receive Interrupt, if enabled. Also, the OWN bit is cleared by the IDMAC by performing a write transaction to DES0.

- Interrupts

Interrupts can be generated as a result of various events. SDMMC\_IDSTS register contains all the bits that might cause an interrupt. SDMMC\_IDINTEN register contains an Enable bit for each of the events that can cause an interrupt.

There are two groups of summary interrupts-Normal and Abnormal-as outlined in SDMMC\_IDSTS register. Interrupts are cleared by writing a 1 to the corresponding bit position. When all the enabled interrupts within a group are cleared, the corresponding summary bit is cleared. When both the summary bits are cleared, the interrupt signal dmac\_intr\_o is de-asserted.

Interrupts are not queued and if the interrupt event occurs before the driver has responded to it, no additional interrupts are generated. For example, Receive Interrupt—SDMMC\_IDSTS[1] indicates that one or more data was transferred to the Host buffer. An interrupt is generated only once for simultaneous, multiple events. The driver must scan SDMMC\_IDSTS register for the interrupt cause.

## 3.4 Register Description

### 3.4.1 Registers Summary

| Name                 | Offset | Size | Reset Value | Description                                      |
|----------------------|--------|------|-------------|--------------------------------------------------|
| <u>SDMMC_CTRL</u>    | 0x0000 | W    | 0x00000000  | Control register                                 |
| <u>SDMMC_PWREN</u>   | 0x0004 | W    | 0x00000000  | Power-enable register                            |
| <u>SDMMC_CLKDIV</u>  | 0x0008 | W    | 0x00000000  | Clock-divider register                           |
| <u>SDMMC_CLKSRC</u>  | 0x000c | W    | 0x00000000  | SD Clock Source Register                         |
| <u>SDMMC_CLKENA</u>  | 0x0010 | W    | 0x00000000  | Clock-enable register                            |
| <u>SDMMC_TMOUT</u>   | 0x0014 | W    | 0xfffffff40 | Time-out register                                |
| <u>SDMMC_CTYPE</u>   | 0x0018 | W    | 0x00000000  | Card-type register                               |
| <u>SDMMC_BLKSIZ</u>  | 0x001c | W    | 0x00000200  | Block-size register                              |
| <u>SDMMC_BYTCNT</u>  | 0x0020 | W    | 0x00000200  | Byte-count register                              |
| <u>SDMMC_INTMASK</u> | 0x0024 | W    | 0x00000000  | Interrupt-mask register                          |
| <u>SDMMC_CMDARG</u>  | 0x0028 | W    | 0x00000000  | Command-argument register                        |
| <u>SDMMC_CMD</u>     | 0x002c | W    | 0x00000000  | Command register                                 |
| <u>SDMMC_RESP0</u>   | 0x0030 | W    | 0x00000000  | Response-0 register                              |
| <u>SDMMC_RESP1</u>   | 0x0034 | W    | 0x00000000  | Response-1 register                              |
| <u>SDMMC_RESP2</u>   | 0x0038 | W    | 0x00000000  | Response-2 register                              |
| <u>SDMMC_RESP3</u>   | 0x003c | W    | 0x00000000  | Response-3 register                              |
| <u>SDMMC_MINTSTS</u> | 0x0040 | W    | 0x00000000  | Masked interrupt-status register                 |
| <u>SDMMC_RINTSTS</u> | 0x0044 | W    | 0x00000000  | Raw interrupt-status register                    |
| <u>SDMMC_STATUS</u>  | 0x0048 | W    | 0x00000406  | Status register                                  |
| <u>SDMMC_FIFOTH</u>  | 0x004c | W    | 0x00000000  | FIFO threshold register                          |
| <u>SDMMC_CDETECT</u> | 0x0050 | W    | 0x00000000  | Card-detect register                             |
| <u>SDMMC_WRTPRT</u>  | 0x0054 | W    | 0x00000000  | Write-protect register                           |
| <u>SDMMC_TCBCNT</u>  | 0x005c | W    | 0x00000000  | Transferred CIU card byte count                  |
| <u>SDMMC_TBBCNT</u>  | 0x0060 | W    | 0x00000000  | Transferred host/DMA to/from BIU-FIFO byte count |

| Name                 | Offset | Size | Reset Value | Description                                       |
|----------------------|--------|------|-------------|---------------------------------------------------|
| SDMMC DEBNCE         | 0x0064 | W    | 0x00ffffff  | Card detect debounce register                     |
| SDMMC USRID          | 0x0068 | W    | 0x07967797  | User ID register                                  |
| SDMMC VERID          | 0x006c | W    | 0x5342270a  | Synopsys version ID register                      |
| SDMMC HCON           | 0x0070 | W    | 0x00000000  | Hardware configuration register                   |
| SDMMC UHS_REG        | 0x0074 | W    | 0x00000000  | UHS-1 register                                    |
| SDMMC RSTN           | 0x0078 | W    | 0x00000001  | Hardware reset register                           |
| SDMMC BMOD           | 0x0080 | W    | 0x00000000  | Bus mode register                                 |
| SDMMC PLDMND         | 0x0084 | W    | 0x00000000  | Poll demand register                              |
| SDMMC DBADDR         | 0x0088 | W    | 0x00000000  | Descriptor list base address register             |
| SDMMC IDSTS          | 0x008c | W    | 0x00000000  | Internal DMAC status register                     |
| SDMMC IDINTEN        | 0x0090 | W    | 0x00000000  | Internal DMAC interrupt enable register           |
| SDMMC DSCADDR        | 0x0094 | W    | 0x00000000  | Current host descriptor address register          |
| SDMMC BUFADDR        | 0x0098 | W    | 0x00000000  | Current buffer descriptor address register        |
| SDMMC CARDTHRCTL     | 0x0100 | W    | 0x00000000  | Card read threshold enable register               |
| SDMMC BACK END POWER | 0x0104 | W    | 0x00000000  | Back-end power register                           |
| SDMMC EMMC DDR REG   | 0x010c | W    | 0x00000000  | eMMC 4.5 ddr start bit detection control register |
| SDMMC FIFO_BASE      | 0x0200 | W    | 0x00000000  | FIFO base address register                        |

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

### 3.4.2 Detail Register Description

#### SDMMC CTRL

Address: Operational Base + offset (0x0000)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                           |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:26 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                              |
| 25    | RW   | 0x0         | use_internal_dmac<br>Present only for the Internal DMAC configuration; else, it is reserved.<br>1'b0: The host performs data transfers through the slave interface<br>1'b1: Internal DMAC used for data transfe                                                                                                                                                                       |
| 24:12 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                              |
| 11    | RW   | 0x0         | ceata_device_interrupt_status<br>1'b0: Interrupts not enabled in CE-ATA device<br>1'b1: Interrupts are enabled in CE-ATA device<br>Software should appropriately write to this bit after power-on reset or any other reset to CE-ATA device. After reset, usually CE-ATA device interrupt is disabled. If the host enables CE-ATA device interrupt, then software should set this bit |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10         | RW          | 0x0                | <p>send_auto_stop_ccsd<br/>1'b0: Clear bit if DWC_mobile_storage does not reset the bit.<br/>1'b1: Send internally generated STOP after sending CCSD to CE-ATA device.</p> <p>NOTE: Always set send_auto_stop_ccsd and send_ccsd bits together send_auto_stop_ccsd should not be set independent of send_ccsd.</p> <p>When set, the Host Controller automatically sends internally-generated STOP command (CMD12) to CE-ATA device. After sending internally-generated STOP command, Auto Command Done (ACD) bit in SDMMC_RINTSTS is set and generates interrupt to host if Auto Command Done interrupt is not masked. After sending the CCSD, DWC_mobile_storage automatically clears send_auto_stop_ccsd bit</p>                                                                                                                            |
| 9          | RW          | 0x0                | <p>send_ccsd<br/>1'b0: Clear bit if DWC_mobile_storage does not reset the bit<br/>1'b1: Send Command Completion Signal Disable (CCSD) to CE-ATA device</p> <p>When set, DWC_mobile_storage sends CCSD to CE-ATA device. Software sets this bit only if current command is expecting CCS (that is, RW_BLK) and interrupts are enabled in CE-ATA device. Once the CCSD pattern is sent to device, DWC_mobile_storage automatically clears send_ccsd bit. It also sets Command Done (CD) bit in SDMMC_RINTSTS register and generates interrupt to host if Command Done interrupt is not masked.</p> <p>NOTE: Once send_ccsd bit is set, it takes two card clock cycles to drive the CCSD on the CMD line. Due to this, during the boundary conditions it may happen that CCSD is sent to the CE-ATA device, even if the device signalled CCS</p> |
| 8          | RW          | 0x0                | <p>abort_read_data<br/>1'b0: no change<br/>1'b1: after suspend command is issued during read-transfer, software polls card to find when suspend happened. Once suspend occurs, software sets bit to reset data state-machine, which is waiting for next block of data. Bit automatically clears once data state machine resets to idle.</p> <p>Used in SDIO card suspend sequence</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7          | RW          | 0x0                | <p>send_irq_response<br/>1'b0: no change<br/>1'b1: send auto IRQ response<br/>Bit automatically clears once response is sent.</p> <p>To wait for MMC card interrupts, host issues 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</p> |
| 6          | RW          | 0x0                | <p>read_wait<br/>1'b0: clear read wait<br/>1'b1: assert read wait<br/>For sending read-wait to SDIO cards</p>                                                                                                                                                                                                                                                                                                                                                                     |
| 5          | RW          | 0x0                | <p>dma_enable<br/>1'b0: disable DMA transfer mode<br/>1'b1: enable DMA transfer mode<br/>Even when DMA mode is enabled, host can still push/pop data into or from FIFO; this should not happen during the normal operation. If there is simultaneous FIFO access from host/DMA, the data coherency is lost. Also, there is no arbitration inside SDMMC Controller to prioritize simultaneous host/DMA access</p>                                                                  |
| 4          | RW          | 0x0                | <p>int_enable<br/>Global interrupt enable/disable bit:<br/>1'b0: disable interrupts<br/>1'b1: enable interrupts<br/>The int port is 1 only when this bit is 1 and one or more unmasked interrupts are set</p>                                                                                                                                                                                                                                                                     |
| 3          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 2          | RW          | 0x0                | <p>dma_reset<br/>1'b0: no change<br/>1'b1: reset internal DMA interface control logic<br/>To reset DMA interface, firmware should set bit to 1.<br/>This bit is auto-cleared after two AHB clocks</p>                                                                                                                                                                                                                                                                             |
| 1          | RW          | 0x0                | <p>fifo_reset<br/>1'b0: no change<br/>1'b1: reset to data FIFO To reset FIFO pointers<br/>To reset FIFO, firmware should set bit to 1.<br/>This bit is auto-cleared after completion of reset operation</p>                                                                                                                                                                                                                                                                       |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0          | RW          | 0x0                | <p>controller_reset<br/>1'b0: no change<br/>1'b1: reset SDMMC controller<br/>To reset controller, firmware should set bit to 1.<br/>This bit is auto-cleared after two AHB and two cclk_in clock cycles.</p> <p>This resets:</p> <ul style="list-style-type: none"> <li>a. BIU/CIU interface</li> <li>b. CIU and state machines</li> <li>c. abort_read_data, send_irq_response, and read_wait bits of Control register</li> <li>d. start_cmd bit of Command register</li> </ul> <p>Does not affect any registers or DMA interface, or FIFO or host interrupts</p> |

**SDMMC PWREN**

Address: Operational Base + offset (0x0004)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                              |
| 0          | RW          | 0x0                | <p>power_enable<br/>Power on/off switch for the card.<br/>Once power is turned on, firmware should wait for regulator/switch ramp-up time before trying to initialize card.</p> <p>1'b0: power off<br/>1'b1: power on<br/>Bit values output to card_power_en port</p> |

**SDMMC CLKDIV**

Address: Operational Base + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                             |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                                                                                                                                                                       |
| 7:0        | RW          | 0x00               | <p>clk_divider0<br/>Clock divider-0 value. Clock division is 2*n.<br/>For example, value of 0 means divide by 2*0 = 0 (no division, bypass), value of 1 means divide by 2*1 = 2, and so on</p> |

**SDMMC CLKSRC**

Address: Operational Base + offset (0x000c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                     |
| 1:0        | RW          | 0x0                | clk_source<br>Clock divider source for up to 16 SD cards supported. Each card has two bits assigned to it. For example, bits[1:0] assigned for card-0, which maps and internally routes clock divider[3:0] outputs to cclk_out[15:0] pins, depending on bit value.<br>2'b00: clock divider 0 |

**SDMMC CLKENA**

Address: Operational Base + offset (0x0010)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:17      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                    |
| 16         | RW          | 0x0                | cclk_low_power<br>Low-power control for SD card clock and MMC card clock supported.<br>1'b0: non-low-power mode<br>1'b1: low-power mode; stop clock when card in IDLE (should be normally set to only MMC and SD memory cards; for SDIO cards, if interrupts must be detected, clock should not be stopped) |
| 15:1       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                    |
| 0          | RW          | 0x0                | cclk_enable<br>Clock-enable control for SD card clock and MMC card clock supported.<br>1'b0: clock disabled<br>1'b1: clock enabled                                                                                                                                                                          |

**SDMMC TMOUT**

Address: Operational Base + offset (0x0014)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RW          | 0x0000000          | data_timeout<br>Value for card Data Read Timeout; same value also used for Data Starvation by Host timeout.<br>Value is in number of card output clocks cclk_out of selected card.<br>Note: The software timer should be used if the timeout value is in the order of 100 ms. In this case, read data timeout interrupt needs to be disabled |
| 7:0        | RW          | 0x40               | response_timeout<br>Response timeout value.<br>Value is in number of card output clock                                                                                                                                                                                                                                                       |

**SDMMC CTYPE**

Address: Operational Base + offset (0x0018)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------|
| 31:17      | RO          | 0x0                | reserved                                                                                   |
| 16         | RW          | 0x0                | card_width_8<br>Indicates if card is 8-bit.<br>1'b0: non 8-bit mode<br>1'b1: 8-bit mode    |
| 15:1       | RO          | 0x0                | reserved                                                                                   |
| 0          | RW          | 0x0                | card_width<br>Indicates if card is 1-bit or 4-bit.<br>1'b0: 1-bit mode<br>1'b1: 4-bit mode |

**SDMMC\_BLKSIZ**

Address: Operational Base + offset (0x001c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>       |
|------------|-------------|--------------------|--------------------------|
| 31:16      | RO          | 0x0                | reserved                 |
| 15:0       | RW          | 0x0000             | block_size<br>Block size |

**SDMMC\_BYTCNT**

Address: Operational Base + offset (0x0020)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | byte_count<br>Number of bytes to be transferred; should be integer multiple of Block Size for block transfers.<br>For undefined number of byte transfers, byte count should be set to 0. When byte count is set to 0, it is responsibility of host to explicitly send stop/abort command to terminate data transfer |

**SDMMC\_INTMASK**

Address: Operational Base + offset (0x0024)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                               |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:25      | RO          | 0x0                | reserved                                                                                                                                                         |
| 24         | RW          | 0x0                | sdio_int_mask<br>Mask SDIO interrupts.<br>When masked, SDIO interrupt detection for that card is disabled.<br>A 0 masks an interrupt, and 1 enables an interrupt |
| 23:17      | RO          | 0x0                | reserved                                                                                                                                                         |
| 16         | RW          | 0x0                | data_nobusy_int_mask<br>1'b0: data no busy interrupt not masked<br>1'b1: data no busy interrupt masked                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0       | RW          | 0x0000             | <p>int_mask<br/>Bits used to mask unwanted interrupts. Value of 0 masks interrupt; value of 1 enables interrupt.</p> <p>bit 15: End-bit error (read)/Write no CRC (EBE)<br/>bit 14: Auto command done (ACD)<br/>bit 13: Start-bit error (SBE)<br/>bit 12: Hardware locked write error (HLE)<br/>bit 11: FIFO underrun/overrun error (FRUN)<br/>bit 10: Data starvation-by-host timeout (HTO) /Volt_switch_int<br/>bit 9: Data read timeout (DRTO)<br/>bit 8: Response timeout (RTO)<br/>bit 7: Data CRC error (DCRC)<br/>bit 6: Response CRC error (RCRC)<br/>bit 5: Receive FIFO data request (RXDR)<br/>bit 4: Transmit FIFO data request (TXDR)<br/>bit 3: Data transfer over (DTO)<br/>bit 2: Command done (CD)<br/>bit 1: Response error (RE)<br/>bit 0: Card detect (CD)</p> |

**SDMMC\_CMDARG**

Address: Operational Base + offset (0x0028)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | <p>cmd_arg<br/>Value indicates command argument to be passed to card</p> |

**SDMMC\_CMD**

Address: Operational Base + offset (0x002c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RW          | 0x0                | <p>start_cmd<br/>Start command. Once command is taken by CIU, bit is cleared.<br/>When bit is set, host should not attempt to write to any command registers. If write is attempted, hardware lock error is set in raw interrupt register.<br/>Once command is sent and response is received from SD_MMC cards, Command Done bit is set in raw interrupt register</p> |
| 30         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                              |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 29         | RW          | 0x0                | <p>use_hold_reg<br/>Use Hold Register.</p> <p>1'b0: CMD and DATA sent to card bypassing HOLD Register<br/>1'b1: CMD and DATA sent to card through the HOLD Register</p> <p>Note:</p> <ul style="list-style-type: none"> <li>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.</li> <li>b. Set to 1'b0 for SDR50, SDR104, and DDR50 (with zero phase-shifted cclk_in_drv)</li> <li>c. Set to 1'b1 for SDR50, SDR104, and DDR50 (with non-zero phase-shifted cclk_in_drv)</li> </ul> |
| 28         | RW          | 0x0                | <p>volt_switch<br/>Voltage switch bit.</p> <p>1'b0: no voltage switching<br/>1'b1: voltage switching enabled; must be set for CMD11 only</p>                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 27         | RW          | 0x0                | <p>boot_mode<br/>Boot Mode.</p> <p>1'b0: mandatory boot operation<br/>1'b1: alternate boot operation</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 26         | RW          | 0x0                | <p>disable_boot<br/>Disable boot.</p> <p>When software sets this bit along with start_cmd, CIU terminates the boot operation. Do NOT set disable_boot and enable_boot together</p>                                                                                                                                                                                                                                                                                                                                                                             |
| 25         | RW          | 0x0                | <p>expect_boot_ack<br/>Expect Boot Acknowledge.</p> <p>When Software sets this bit along with enable_boot, CIU expects a boot acknowledge start pattern of 0-1-0 from the selected card</p>                                                                                                                                                                                                                                                                                                                                                                    |
| 24         | RW          | 0x0                | <p>enable_boot<br/>Enable Boot.</p> <p>This bit should be set only for mandatory boot mode. When Software sets this bit along with start_cmd, CIU starts the boot sequence for the corresponding card by asserting the CMD line low. Do NOT set disable_boot and enable_boot together</p>                                                                                                                                                                                                                                                                      |
| 23         | RW          | 0x0                | <p>ccs_expected<br/>1'b0: command does not expect CCS from device<br/>1'b1: command expects CCS from device</p> <p>If the command expects Command Completion Signal (CCS) from the CE-ATA device, the software should set this control bit. The Host Controller sets Data Transfer Over (DTO) bit in SDMMC_RINTSTS register and generates interrupt to host if Data Transfer Over interrupt is not masked</p>                                                                                                                                                  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 22         | RW          | 0x0                | <p>read_ceata_device<br/>1'b0: Host is not performing read access (RW_REG or RW_BLK) towards CE-ATA device<br/>1'b1: Host is performing read access (RW_REG or RW_BLK) towards CE-ATA device</p> <p>Software should set this bit to indicate that CE-ATA device is being accessed for read transfer. This bit is used to disable read data timeout indication while performing CE-ATA read transfers. Maximum value of I/O transmission delay can be no less than 10 seconds. DWC_mobile_storage should not indicate read data timeout while waiting for data from CE-ATA device</p>                                                                                                                                                                                                                                        |
| 21         | RW          | 0x0                | <p>update_clock_registers_only<br/>1'b0: normal command sequence<br/>1'b1: do not send commands, just update clock register value into card clock domain</p> <p>Following register values transferred into card clock domain: CLKDIV, CLRSRC, CLKENA.</p> <p>Changes card clocks (change frequency, truncate off or on, and set low-frequency mode); provided in order to change clock frequency or stop clock without having to send command to cards.</p> <p>During normal command sequence, when update_clock_registers_only=0, following control registers are transferred from BIU to CIU: CMD, CMDARG, TMOUT, CTYPE, BLKSIZ, BYTCNT. CIU uses new register values for new command sequence to card.</p> <p>When bit is set, there are no Command Done interrupts because no command is sent to SD_MMC_CEATA cards</p> |
| 20:16      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 15         | RW          | 0x0                | <p>send_initialization<br/>1'b0: do not send initialization sequence (80 clocks of 1) before sending this command<br/>1'b1: send initialization sequence before sending this command</p> <p>After power on, 80 clocks must be sent to card for initialization before sending any commands to card. Bit should be set while sending first command to card so that controller will initialize clocks before sending command to card. This bit should not be set for either of the boot modes (alternate or mandatory)</p>                                                                                                                                                                                                                                                                                                     |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14         | RW          | 0x0                | <p>stop_abort_cmd<br/>           1'b0: neither stop nor abort command to stop current data transfer in progress. If abort is sent to function-number currently selected or not in data-transfer mode, then bit should be set to 0.<br/>           1'b1: stop or abort command intended to stop current data transfer in progress.</p> <p>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</p> |
| 13         | RW          | 0x0                | <p>wait_prvdata_complete<br/>           1'b0: send command at once, even if previous data transfer has not completed<br/>           1'b1: wait for previous data transfer completion before sending command</p> <p>The wait_prvdata_complete=0 option typically used to query status of card during data transfer or to stop current data transfer; card_number should be same as in previous command</p>                                                                                                                                                                                                                                                                                          |
| 12         | RW          | 0x0                | <p>send_auto_stop<br/>           1'b0: no stop command sent at end of data transfer<br/>           1'b1: send stop command at end of data transfer</p> <p>When set, SDMMC Controller sends stop command to SD_MMC cards at end of data transfer.</p> <p>a. when send_auto_stop bit should be set, since some data transfers do not need explicit stop commands<br/>           b. open-ended transfers that software should explicitly send to stop command</p> <p>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.</p> <p>Don't care if no data expected from card</p>         |
| 11         | RW          | 0x0                | <p>transfer_mode<br/>           1'b0: block data transfer command<br/>           1'b1: stream data transfer command</p> <p>Don't care if no data expected</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 10         | RW          | 0x0                | <p>wr<br/>           1'b0: read from card<br/>           1'b1: write to card</p> <p>Don't care if no data expected from card</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 9          | RW          | 0x0                | <p>data_expected<br/>           1'b0: no data transfer expected (read/write)<br/>           1'b1: data transfer expected (read/write)</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8          | RW          | 0x0                | check_response_crc<br>1'b0: do not check response CRC<br>1'b1: check response CRC<br>Some of command responses do not return valid CRC bits.<br>Software should disable CRC checks for those commands in order to disable CRC checking by controller |
| 7          | RW          | 0x0                | response_length<br>1'b0: short response expected from card<br>1'b1: long response expected from card                                                                                                                                                 |
| 6          | RW          | 0x0                | response_expect<br>1'b0: no response expected from card<br>1'b1: response expected from card                                                                                                                                                         |
| 5:0        | RW          | 0x00               | cmd_index<br>Command index                                                                                                                                                                                                                           |

**SDMMC RESP0**

Address: Operational Base + offset (0x0030)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                 |
|------------|-------------|--------------------|------------------------------------|
| 31:0       | RO          | 0x00000000         | response0<br>Bit[31:0] of response |

**SDMMC RESP1**

Address: Operational Base + offset (0x0034)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | response1<br>Register represents bit[63:32] of long response.<br>When CIU sends auto-stop command, then response is saved in register. Response for previous command sent by host is still preserved in Response 0 register. Additional auto-stop issued only for data transfer commands, and response type is always "short" for them |

**SDMMC RESP2**

Address: Operational Base + offset (0x0038)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                       |
|------------|-------------|--------------------|------------------------------------------|
| 31:0       | RO          | 0x00000000         | response2<br>Bit[95:64] of long response |

**SDMMC RESP3**

Address: Operational Base + offset (0x003c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                        |
|------------|-------------|--------------------|-------------------------------------------|
| 31:0       | RW          | 0x00000000         | response3<br>Bit[127:96] of long response |

**SDMMC\_MINTSTS**

Address: Operational Base + offset (0x0040)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:25      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 24         | RW          | 0x0                | <p>sdio_interrupt<br/>Interrupt from SDIO card; SDIO interrupt for card enabled only if corresponding sdio_int_mask bit is set in Interrupt mask register (mask bit 1 enables interrupt; 0 masks interrupt).</p> <p>1'b0: no SDIO interrupt from card<br/>1'b1: SDIO interrupt from card</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 23:17      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 16         | RW          | 0x0                | <p>data_nobusy_int_status<br/>Data no busy interrupt status, high active</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 15:0       | RW          | 0x0000             | <p>int_status<br/>Interrupt enabled only if corresponding bit in interrupt mask register is set.</p> <p>bit 15: End-bit error (read)/Write no CRC (EBE)<br/>bit 14: Auto command done (ACD)<br/>bit 13: Start-bit error (SBE)<br/>bit 12: Hardware locked write error (HLE)<br/>bit 11: FIFO underrun/overrun error (FRUN)<br/>bit 10: Data starvation-by-host timeout (HTO) /Volt_switch_int<br/>bit 9: Data read timeout (DRTO)<br/>bit 8: Response timeout (RTO)<br/>bit 7: Data CRC error (DCRC)<br/>bit 6: Response CRC error (RCRC)<br/>bit 5: Receive FIFO data request (RXDR)<br/>bit 4: Transmit FIFO data request (TXDR)<br/>bit 3: Data transfer over (DTO)<br/>bit 2: Command done (CD)<br/>bit 1: Response error (RE)<br/>bit 0: Card detect (CD)</p> |

**SDMMC\_RINTSTS**

Address: Operational Base + offset (0x0044)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:25      | RO          | 0x0                | reserved                                                                                                                                                                                                        |
| 24         | RW          | 0x0                | <p>sdio_interrupt<br/>Interrupt from SDIO card; Writes to these bits clear them. Value of 1 clears bit and 0 leaves bit intact.</p> <p>1'b0: no SDIO interrupt from card<br/>1'b1: SDIO interrupt from card</p> |
| 23:17      | RO          | 0x0                | reserved                                                                                                                                                                                                        |
| 16         | RW          | 0x0                | <p>data_nobusy_int_status<br/>Data no busy interrupt status, high active</p>                                                                                                                                    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0       | RW          | 0x0000             | <p>int_status</p> <p>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.</p> <p>bit 15: End-bit error (read)/Write no CRC (EBE)</p> <p>bit 14: Auto command done (ACD)</p> <p>bit 13: Start-bit error (SBE)</p> <p>bit 12: Hardware locked write error (HLE)</p> <p>bit 11: FIFO underrun/overrun error (FRUN)</p> <p>bit 10: Data starvation-by-host timeout (HTO) /Volt_switch_int</p> <p>bit 9: Data read timeout (DRTO)</p> <p>bit 8: Response timeout (RTO)</p> <p>bit 7: Data CRC error (DCRC)</p> <p>bit 6: Response CRC error (RCRC)</p> <p>bit 5: Receive FIFO data request (RXDR)</p> <p>bit 4: Transmit FIFO data request (TXDR)</p> <p>bit 3: Data transfer over (DTO)</p> <p>bit 2: Command done (CD)</p> <p>bit 1: Response error (RE)</p> <p>bit 0: Card detect (CD)</p> |

**SDMMC STATUS**

Address: Operational Base + offset (0x0048)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RW          | 0x0                | <p>dma_req</p> <p>DMA request signal state</p>                                                                                                                                                      |
| 30         | RO          | 0x0                | <p>dma_ack</p> <p>DMA acknowledge signal state</p>                                                                                                                                                  |
| 29:17      | RO          | 0x0000             | <p>fifo_count</p> <p>Number of filled locations in FIFO</p>                                                                                                                                         |
| 16:11      | RO          | 0x00               | <p>response_index</p> <p>Index of previous response, including any auto-stop sent by core</p>                                                                                                       |
| 10         | RO          | 0x1                | <p>data_state_mc_busy</p> <p>Data transmit or receive state-machine is busy</p>                                                                                                                     |
| 9          | RW          | 0x0                | <p>data_busy</p> <p>Inverted version of raw selected card_data[0].</p> <p>1'b0: card data not busy</p> <p>1'b1: card data busy</p> <p>default value is 1 or 0 depending on cdata_in</p>             |
| 8          | RW          | 0x0                | <p>data_3_status</p> <p>Raw selected card_data[3]; checks whether card is present.</p> <p>1'b0: card not present</p> <p>1'b1: card present</p> <p>default value is 1 or 0 depending on cdata_in</p> |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:4 | RW   | 0x0         | <p>command_fsm_states<br/>Command FSM states:<br/>4'h0: idle<br/>4'h1: send init sequence<br/>4'h2: Tx cmd start bit<br/>4'h3: Tx cmd tx bit<br/>4'h4: Tx cmd index + arg<br/>4'h5: Tx cmd crc7<br/>4'h6: Tx cmd end bit<br/>4'h7: Rx resp start bit<br/>4'h8: Rx resp IRQ response<br/>4'h9: Rx resp tx bit<br/>4'ha: Rx resp cmd idx<br/>4'hb: Rx resp data<br/>4'hc: Rx resp crc7<br/>4'hd: Rx resp end bit<br/>4'he: Cmd path wait NCC<br/>4'hf: Wait; CMD-to-response turnaround</p> <p>The command FSM state is represented using 19 bits.<br/>The SDMMC_STATUS Register[7:4] has 4 bits to represent the command FSM states. Using these 4 bits, only 16 states can be represented. Thus three states cannot be represented in the SDMMC_STATUS[7:4] register. The three states that are not represented in the SDMMC_STATUS Register[7:4] are:</p> <ul style="list-style-type: none"> <li>Bit 16: Wait for CCS</li> <li>Bit 17: Send CCSD</li> <li>Bit 18: Boot Mode</li> </ul> <p>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 field [7:4]</p> |
| 3   | RO   | 0x0         | fifo_full<br>FIFO is full status                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 2   | RO   | 0x1         | fifo_empty<br>FIFO is empty status                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 1   | RO   | 0x1         | fifo_tx_watermark<br>FIFO reached Transmit watermark level; not qualified with data transfer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 0   | RO   | 0x0         | fifo_rx_watermark<br>FIFO reached Receive watermark level; not qualified with data transfer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

**SDMMC FIFO TH**

Address: Operational Base + offset (0x004c)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 30:28      | RW          | 0x0                | <p>dma_multiple_transaction_size<br/>         Burst size of multiple transaction; should be programmed same as DMA controller multiple-transaction-size SRC/DEST_MSIZE.<br/>         3'b000: 1 transfers<br/>         3'b001: 4<br/>         3'b010: 8<br/>         3'b011: 16<br/>         3'b100: 32<br/>         3'b101: 64<br/>         3'b110: 128<br/>         3'b111: 256</p> <p>The unit for transfer is the H_DATA_WIDTH parameter. A single transfer (dw_dma_single assertion in case of Non DW DMA interface) would be signalled based on this value.</p> <p>Value should be sub-multiple of <math>(RX\_WMark + 1) * (F\_DATA\_WIDTH/H\_DATA\_WIDTH)</math> and <math>(FIFO\_DEPTH - TX\_WMark) * (F\_DATA\_WIDTH/ H\_DATA\_WIDTH)</math></p> <p>For example, if FIFO_DEPTH = 16, FDATA_WIDTH == H_DATA_WIDTH</p> <p>Allowed combinations for MSize and TX_WMark are:</p> <ul style="list-style-type: none"> <li>MSize = 1, TX_WMARK = 1-15</li> <li>MSize = 4, TX_WMark = 8</li> <li>MSize = 4, TX_WMark = 4</li> <li>MSize = 4, TX_WMark = 12</li> <li>MSize = 8, TX_WMark = 8</li> <li>MSize = 8, TX_WMark = 4</li> </ul> <p>Allowed combinations for MSize and RX_WMark are:</p> <ul style="list-style-type: none"> <li>MSize = 1, RX_WMARK = 0-14</li> <li>MSize = 4, RX_WMark = 3</li> <li>MSize = 4, RX_WMark = 7</li> <li>MSize = 4, RX_WMark = 11</li> <li>MSize = 8, RX_WMark = 7</li> </ul> <p>Recommended:</p> <ul style="list-style-type: none"> <li>MSize = 8, TX_WMark = 8, RX_WMark = 7</li> </ul> |

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 27:16 | RW   | 0x000       | <p>rx_wmark<br/>FIFO threshold watermark level when receiving data to card.<br/>When FIFO data count reaches greater than this number,<br/>DMA/FIFO request is raised. During end of packet, request is<br/>generated regardless of threshold programming in order to<br/>complete any remaining data.</p> <p>In non-DMA mode, when receiver FIFO threshold (RXDR)<br/>interrupt is enabled, then interrupt is generated instead of DMA<br/>request. During end of packet, interrupt is not generated if<br/>threshold programming is larger than any remaining data. It is<br/>responsibility of host to read remaining bytes on seeing Data<br/>Transfer Done interrupt.</p> <p>In DMA mode, at end of packet, even if remaining bytes are less<br/>than threshold, DMA request does single transfers to flush out<br/>any remaining bytes before Data Transfer Done interrupt is set.<br/>12 bits-1 bit less than FIFO-count of status register, which is 13<br/>bits.</p> <p>Limitation: RX_WMark &lt;= FIFO_DEPTH-2<br/>Recommended: (FIFO_DEPTH/2) - 1; (means greater than<br/>(FIFO_DEPTH/2) - 1)</p> <p>NOTE: In DMA mode during CCS time-out, the DMA does not<br/>generate the request at the end of packet, even if remaining<br/>bytes are less than threshold. In this case, there will be some<br/>data left in the FIFO. It is the responsibility of the application to<br/>reset the FIFO after the CCS timeout</p> |
| 15:12 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 11:0  | RW   | 0x000       | <p>tx_wmark<br/>FIFO threshold watermark level when transmitting data to card.<br/>When FIFO data count is less than or equal to this number,<br/>DMA/FIFO request is raised. If Interrupt is enabled, then interrupt<br/>occurs. During end of packet, request or interrupt is generated,<br/>regardless of threshold programming.</p> <p>In non-DMA mode, when transmit FIFO threshold (TXDR)<br/>interrupt is enabled, then interrupt is generated instead of DMA<br/>request. During end of packet, on last interrupt, host is<br/>responsible for filling FIFO with only required remaining bytes<br/>(not before FIFO is full or after CIU completes data transfers,<br/>because FIFO may not be empty).</p> <p>In DMA mode, at end of packet, if last transfer is less than burst<br/>size, DMA controller does single cycles until required bytes are<br/>transferred.</p> <p>12 bits -1 bit less than FIFO-count of status register, which is 13<br/>bits.</p> <p>Limitation: TX_WMark &gt;= 1;<br/>Recommended: FIFO_DEPTH/2; (means less than or equal to<br/>FIFO_DEPTH/2)</p>                                                                                                                                                                                                                                                                                                                                           |

**SDMMC\_CDETECT**

Address: Operational Base + offset (0x0050)

| Bit  | Attr | Reset Value | Description                                                                                        |
|------|------|-------------|----------------------------------------------------------------------------------------------------|
| 31:1 | RO   | 0x0         | reserved                                                                                           |
| 0    | RO   | 0x0         | card_detect_n<br>Value on card_detect_n input ports; read-only bits. 0 represents presence of card |

**SDMMC\_WRPRT**

Address: Operational Base + offset (0x0054)

| Bit  | Attr | Reset Value | Description                                                                        |
|------|------|-------------|------------------------------------------------------------------------------------|
| 31:1 | RO   | 0x0         | reserved                                                                           |
| 0    | RW   | 0x0         | write_protect<br>Value on card_write_prt input port. 1 represents write protection |

**SDMMC\_TCBCNT**

Address: Operational Base + offset (0x005c)

| Bit  | Attr | Reset Value | Description                                                                                                                                   |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | trans_card_byte_count<br>Number of bytes transferred by CIU unit to card.<br>Both SDMMC_TCBCNT and SDMMC_TBBCNT share same coherency register |

**SDMMC\_TBBCNT**

Address: Operational Base + offset (0x0060)

| Bit  | Attr | Reset Value | Description                                                                                                                                                |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | trans_fifo_byte_count<br>Number of bytes transferred between Host/DMA memory and FIFO.<br>Both SDMMC_TCBCNT and SDMMC_TBBCNT share same coherency register |

**SDMMC\_DEBNCE**

Address: Operational Base + offset (0x0064)

| Bit   | Attr | Reset Value | Description                                                                                                   |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------|
| 31:24 | RO   | 0x0         | reserved                                                                                                      |
| 23:0  | RW   | 0xffffffff  | debounce_count<br>Number of host clocks (clk) used by debounce filter logic; typical debounce time is 5-25 ms |

**SDMMC\_USRID**

Address: Operational Base + offset (0x0068)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x07967797         | usrid<br>User identification register; value set by user. Default reset value can be picked by user while configuring core before synthesis.<br>Can also be used as scratch pad register by user.<br>The default value is determined by Configuration Value |

**SDMMC VERID**

Address: Operational Base + offset (0x006c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x5342270a         | verid<br>Version identification register; register value is hard-wired. Can be read by firmware to support different versions of core |

**SDMMC HCON**

Address: Operational Base + offset (0x0070)

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

|      |    |            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------|----|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |    |            | HCON<br>Configuration Dependent.<br>Hardware configurations selected by user before synthesizing core. Register values can be used to develop configuration-independent software drivers.<br>[0]: CARD_TYPE<br>1'b0: MMC_ONLY<br>1'b1: SD_MMC<br>[5:1]: NUM_CARDS - 1<br>[6]: H_BUS_TYPE<br>1'b0: APB<br>1'b1: AHB<br>[9:7]: H_DATA_WIDTH<br>3'b000: 16 bits<br>3'b001: 32 bits<br>3'b010: 64 bits<br>others: reserved<br>[15:10]: H_ADDR_WIDTH<br>0 to 7: reserved<br>6'd8: 9 bits<br>6'd9: 10 bits<br>...<br>6'd31: 32 bits<br>6'd32 to 63: reserved<br>[17:16]: DMA_INTERFACE<br>2'b00: none<br>2'b01: DW_DMA<br>2'b10: GENERIC_DMA<br>2'b11: NON-DW-DMA<br>[20:18]: GE_DMA_DATA_WIDTH<br>3'b000: 16 bits<br>3'b001: 32 bits<br>3'b010: 64 bits<br>others: reserved<br>[21]: FIFO_RAM_INSIDE<br>1'b0: outside<br>1'b1: inside<br>[22]: IMPLEMENT_HOLD_REG<br>1'b0: no hold register<br>1'b1: hold register<br>[23]: SET_CLK_FALSE_PATH<br>1'b0: no false path<br>1'b1: false path set<br>[25:24]: NUM_CLK_DIVIDER-1<br>[26]: AREA_OPTIMIZED<br>1'b0: no area optimization |
| 31:0 | RW | 0x00000000 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

|  |  |                         |
|--|--|-------------------------|
|  |  | 1'b1: Area optimization |
|--|--|-------------------------|

**SDMMC UHS REG**

Address: Operational Base + offset (0x0074)

| Bit   | Attr | Reset Value | Description                                                  |
|-------|------|-------------|--------------------------------------------------------------|
| 31:17 | RO   | 0x0         | reserved                                                     |
| 16    | RW   | 0x0         | ddr_reg<br>DDR mode.<br>1'b0: non-DDR mode<br>1'b1: DDR mode |
| 15:0  | RO   | 0x0         | reserved                                                     |

**SDMMC RSTN**

Address: Operational Base + offset (0x0078)

| Bit  | Attr | Reset Value | Description                                                       |
|------|------|-------------|-------------------------------------------------------------------|
| 31:1 | RO   | 0x0         | reserved                                                          |
| 0    | RW   | 0x0         | card_reset<br>Hardware reset.<br>1'b0: active mode<br>1'b1: reset |

**SDMMC BMOD**

Address: Operational Base + offset (0x0080)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:11 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 10:8  | RW   | 0x0         | PBL<br>Programmable Burst Length. These bits indicate the maximum number of beats to be performed in one IDMAC transaction. The IDMAC will always attempt to burst as specified in PBL each time it starts a Burst transfer on the host bus. The permissible values are 1, 4, 8, 16, 32, 64, 128 and 256. This value is the mirror of MSIZE of FIFOTH register. In order to change this value, write the required value to FIFOTH register. This is an encode value as follows.<br>3'b000: 1 transfers<br>3'b001: 4 transfers<br>3'b010: 8 transfers<br>3'b011: 16 transfers<br>3'b100: 32 transfers<br>3'b101: 64 transfers<br>3'b110: 128 transfers<br>3'b111: 256 transfers<br>Transfer unit is either 16, 32, or 64 bits, based on HDATA_WIDTH.<br>PBL is a read-only value and is applicable only for Data Access; it does not apply to descriptor accesses |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7          | RW          | 0x0                | DE<br>IDMAC Enable.<br>When set, the IDMAC is enabled                                                                                                                                                                                                                                |
| 6:2        | RW          | 0x00               | DSL<br>Descriptor Skip Length.<br>Specifies the number of HWord/Word/Dword (depending on 16/32/64-bit bus) to skip between two unchained descriptors.<br>This is applicable only for dual buffer structure                                                                           |
| 1          | RW          | 0x0                | FB<br>Fixed Burst.<br>Controls whether the AHB Master interface performs fixed burst transfers or not. When set, the AHB will use only SINGLE, INCR4, INCR8 or INCR16 during start of normal burst transfers. When reset, the AHB will use SINGLE and INCR burst transfer operations |
| 0          | RW          | 0x0                | SWR<br>Software Reset. When set, the DMA Controller resets all its internal registers.<br>It is automatically cleared after 1 clock cycle                                                                                                                                            |

**SDMMC PLDMND**

Address: Operational Base + offset (0x0084)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                    |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | WO          | 0x00000000         | PD<br>Poll Demand.<br>If the OWN bit of a descriptor is not set, the FSM goes to the Suspend state. The host needs to write any value into this register for the IDMAC FSM to resume normal descriptor fetch operation. This is a write only register |

**SDMMC DBADDR**

Address: Operational Base + offset (0x0088)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | SDL<br>Start of Descriptor List. Contains the base address of the First Descriptor.<br>The LSB bits [0/1/2:0] for 16/32/64-bit bus-width) are ignored and taken as all-zero by the IDMAC internally. Hence these LSB bits are read-only |

**SDMMC IDSTS**

Address: Operational Base + offset (0x008c)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16:13      | RW          | 0x0                | <p>FSM<br/>DMAC FSM present state.</p> <p>4'h0: DMA_IDLE<br/>4'h1: DMA_SUSPEND<br/>4'h2: DESC_RD<br/>4'h3: DESC_CHK<br/>4'h4: DMA_RD_REQ_WAI<br/>4'h5: DMA_WR_REQ_WAI<br/>4'h6: DMA_RD<br/>4'h7: DMA_WR<br/>4'h8: DESC_CLOSE</p>                                                                                                            |
| 12:10      | RW          | 0x0                | <p>EB<br/>Error Bits. Indicates the type of error that caused a Bus Error.<br/>Valid only with fatal Bus.</p> <p>3'h1: Host Abort received during transmission<br/>3'h2: Host Abort received during reception<br/>Others: Reserved</p>                                                                                                      |
| 9          | RW          | 0x0                | <p>AIS<br/>Abnormal Interrupt Summary. Logical OR of the following:<br/>SDMMC_IDSTS[2] Fatal Bus Interrupt<br/>SDMMC_IDSTS[4] DU bit Interrupt<br/>Only unmasked bits affect this bit.<br/>This is a sticky bit and must be cleared each time a corresponding bit that causes AIS to be set is cleared.<br/>Writing a 1 clears this bit</p> |
| 8          | RW          | 0x0                | <p>NIS<br/>Normal Interrupt Summary. Logical OR of the following:<br/>SDMMC_IDSTS[0] Transmit Interrupt<br/>SDMMC_IDSTS[1] Receive Interrupt<br/>Only unmasked bits affect this bit.<br/>This is a sticky bit and must be cleared each time a corresponding bit that causes NIS to be set is cleared.<br/>Writing a 1 clears this bit</p>   |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5          | RW          | 0x0                | <p>CES<br/>Card Error Summary.<br/>Indicates the status of the transaction to/from the card; also present in SDMMC_RINTSTS. Indicates the logical OR of the following bits:</p> <ul style="list-style-type: none"> <li>EBC: End Bit Error</li> <li>RTO: Response Timeout/Boot Ack Timeout</li> <li>RCRC: Response CRC</li> <li>SBE: Start Bit Error</li> <li>DRTO: Data Read Timeout/BDS timeout</li> <li>DCRC: Data CRC for Receive</li> <li>RE: Response Error</li> </ul> <p>Writing a 1 clears this bit.</p> <p>The abort condition of the IDMAC depends on the setting of this CES bit. If the CES bit is enabled, then the IDMAC aborts on a "response error"; however, it will not abort if the CES bit is cleared</p> |
| 4          | RW          | 0x0                | <p>DU<br/>Descriptor Unavailable Interrupt.<br/>This bit is set when the descriptor is unavailable due to OWN bit = 0 (DES0[31] =0).<br/>Writing a 1 clears this bit</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 3          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 2          | RW          | 0x0                | <p>FBE<br/>Fatal Bus Error Interrupt.<br/>When this bit is set, the DMA disables all its bus accesses.<br/>Writing a 1 clears this bit</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 1          | RW          | 0x0                | <p>RI<br/>Receive Interrupt.<br/>Indicates the completion of data reception for a descriptor.<br/>Writing a 1 clears this bit</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 0          | RW          | 0x0                | <p>TI<br/>Transmit Interrupt.<br/>Indicates that data transmission is finished for a descriptor.<br/>Writing 1 clears this bit</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

**SDMMC\_IDINTEN**

Address: Operational Base + offset (0x0090)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9          | RW          | 0x0                | AI<br>Abnormal Interrupt Summary Enable.<br>When set, an abnormal interrupt is enabled.<br>This bit enables the following bits:<br>SDMMC_IDINTEN[2] Fatal Bus Error Interrupt<br>SDMMC_IDINTEN[4] DU Interrupt                                     |
| 8          | RW          | 0x0                | NI<br>Normal Interrupt Summary Enable.<br>When set, a normal interrupt is enabled. When reset, a normal interrupt is disabled.<br>This bit enables the following bits:<br>SDMMC_IDINTEN[0] Transmit Interrupt<br>SDMMC_IDINTEN[1] Receive Interrup |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                                                                           |
| 5          | RW          | 0x0                | CES<br>Card Error summary Interrupt Enable.<br>When set, it enables the Card Interrupt summary                                                                                                                                                     |
| 4          | RW          | 0x0                | DU<br>Descriptor Unavailable Interrupt.<br>When set along with Abnormal Interrupt Summary Enable, the DU interrupt is enabled                                                                                                                      |
| 3          | RO          | 0x0                | reserved                                                                                                                                                                                                                                           |
| 2          | RW          | 0x0                | FBE<br>Fatal Bus Error Enable.<br>When set with Abnormal Interrupt Summary Enable, the Fatal Bus Error Interrupt is enabled.<br>When reset, Fatal Bus Error Enable Interrupt is disabled                                                           |
| 1          | RW          | 0x0                | RI<br>Receive Interrupt Enable.<br>When set with Normal Interrupt Summary Enable, Receive Interrupt is enabled.<br>When reset, Receive Interrupt is disabled                                                                                       |
| 0          | RW          | 0x0                | TI<br>Transmit Interrupt Enable.<br>When set with Normal Interrupt Summary Enable, Transmit Interrupt is enabled.<br>When reset, Transmit Interrupt is disabled                                                                                    |

**SDMMC\_DSCADDR**

Address: Operational Base + offset (0x0094)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                               |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | HDA<br>Host Descriptor Address Pointer.<br>Cleared on reset. Pointer updated by IDMAC during operation.<br>This register points to the start address of the current descriptor read by the IDMAC |

**SDMMC\_BUFAADDR**

Address: Operational Base + offset (0x0098)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | HBA<br>Host Buffer Address Pointer.<br>Cleared on Reset. Pointer updated by IDMAC during operation.<br>This register points to the current Data Buffer Address being accessed by the IDMAC |

**SDMMC CARDTHRCTL**

Address: Operational Base + offset (0x0100)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 27:16      | RW          | 0x000              | CardRdThreshold<br>Card Read Threshold size                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 15:2       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 1          | RW          | 0x0                | BsyClrIntEn<br>Busy Clear Interrupt generation.<br>1'b0: Busy Clear Interrupt disabled<br>1'b1: Busy Clear Interrupt enabled<br>Note: The application can disable this feature if it does not want to wait for a Busy Clear Interrupt. For example, in a multi-card scenario, the application can switch to the other card without waiting for a busy to be completed. In such cases, the application can use the polling method to determine the status of busy. By default this feature is disabled and backward-compatible to the legacy drivers where polling is used |
| 0          | RW          | 0x0                | CardRdThrEn<br>Card Read Threshold Enable.<br>1'b0: Card Read Threshold disabled<br>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)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x0                | reserved                                                                                                   |
| 0          | RW          | 0x0                | back_end_power<br>Back end power.<br>1'b0: Off; Reset<br>1'b1: Back-end Power supplied to card application |

**SDMMC EMMC DDR REG**

Address: Operational Base + offset (0x010c)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0          | RW          | 0x0                | HALF_START_BIT<br>Control for start bit detection mechanism inside<br>DWC_mobile_storage based on duration of start bit; each bit<br>refers to one slot. For eMMC 4.5, start bit can be:<br>1'b0: Full cycle (HALF_START_BIT=0)<br>1'b1: Less than one full cycle (HALF_START_BIT=1)<br>Set HALF_START_BIT=1 for eMMC 4.5 and above; set to 0 for SD<br>applications |

**SDMMC FIFO BASE**

Address: Operational Base + offset (0x0200)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>               |
|------------|-------------|--------------------|----------------------------------|
| 31:0       | RW          | 0x00000000         | fifo_base_addr<br>Fifo base addr |

### 3.5 Interface Description

The interface and IOMUX setting for SDMMC, SDIO, EMMC are shown as follows.

Table 3-8 SDMMC Interface Description

| <b>Module Pin</b> | <b>Direction</b> | <b>Pad Name</b>                         | <b>IOMUX Setting</b>                |
|-------------------|------------------|-----------------------------------------|-------------------------------------|
| sdmmc_cclk        | O                | IO_SDMMC0clkout_TESTclk0_GPIO1D6vccio2  | GRF_GPIO1D_IOMUX_H[11:8]<br>]=4'b01 |
| sdmmc_ccmd        | I/O              | IO_SDMMC0cmd_GPIO1D7vccio2              | GRF_GPIO1D_IOMUX_H[15:12]=4'b01     |
| sdmmc_cdata0      | I/O              | IO_SDMMC0d0_UART2txm0_GP<br>IO1D2vccio2 | GRF_GPIO1D_IOMUX_L[11:8]<br>=4'b01  |
| sdmmc_cdata1      | I/O              | IO_SDMMC0d1_UART2rxm0_GP<br>IO1D3vccio2 | GRF_GPIO1D_IOMUX_L[15:12]=4'b01     |
| sdmmc_cdata2      | I/O              | IO_SDMMC0d2_JTAGtck_GPIO1D4vccio2       | GRF_GPIO1D_IOMUX_H[3:0]<br>=4'b01   |
| sdmmc_cdata3      | I/O              | IO_SDMMC0d3_JTAGtms_GPIO1D5vccio2       | GRF_GPIO1D_IOMUX_H[7:4]<br>=4'b01   |
| sdmmc_cdtn        | I                | IO_SDMMC0detn_GPIO0A3pmui<br>o1         | GRF_GPIO0A_IOMUX[7:6]<br>=2'b01     |

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

Table 3-9 SDIO Interface Description

| <b>Module Pin</b> | <b>Direction</b> | <b>Pad Name</b>            | <b>IOMUX Setting</b>                |
|-------------------|------------------|----------------------------|-------------------------------------|
| sdio_cclk         | O                | IO_SDMMC1clk_GPIO1C5vccio1 | GRF_GPIO1C_IOMUX_H[7:4]<br>=4'b01   |
| sdio_ccmd         | I/O              | IO_SDMMC1cmd_GPIO1C4vccio1 | GRF_GPIO1C_IOMUX_H[3:0]<br>=4'b01   |
| sdio_cdata0       | I/O              | IO_SDMMC1d0_GPIO1C6vccio1  | GRF_GPIO1C_IOMUX_H[11:8]<br>]=4'b01 |
| sdio_cdata1       | I/O              | IO_SDMMC1d1_GPIO1C7vccio1  | GRF_GPIO1C_IOMUX_H[15:12]=4'b01     |
| sdio_cdata2       | I/O              | IO_SDMMC1d2_GPIO1D0vccio1  | GRF_GPIO1D_IOMUX_L[3:0]<br>=4'b01   |

| Module Pin  | Direction | Pad Name                  | IOMUX Setting                     |
|-------------|-----------|---------------------------|-----------------------------------|
| sdio_cdata3 | I/O       | IO_SDMMC1d3_GPIO1D1vccio1 | GRF_GPIO1D_IOMUX_L[7:4]<br>=4'b01 |

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

Table 3-10 EMMC Interface Description

| Module Pin  | Direction | Pad Name                                     | IOMUX Setting                       |
|-------------|-----------|----------------------------------------------|-------------------------------------|
| emmc_cclk   | O         | IO_FLASHrdy_EMMCclkout_SFC_clk_GPIO1B1vccio0 | GRF_GPIO1B_IOMUX_L[7:4]<br>=4'b10   |
| emmc_ccmd   | I/O       | IO_FLASHdqs_EMMCCcmd_GPIO1B2vccio0           | GRF_GPIO1B_IOMUX_L[11:8]<br>=4'b10  |
| emmc_cdata0 | I/O       | IO_FLASHd0_EMMCd0_SFCsio0_GPIO1A0vccio0      | GRF_GPIO1A_IOMUX_L[3:0]<br>=4'b10   |
| emmc_cdata1 | I/O       | IO_FLASHd1_EMMCd1_SFCsio1_GPIO1A1vccio0      | GRF_GPIO1A_IOMUX_L[7:4]<br>=4'b10   |
| emmc_cdata2 | I/O       | IO_FLASHd2_EMMCd2_SFCsio2_GPIO1A2vccio0      | GRF_GPIO1A_IOMUX_L[11:8]<br>=4'b10  |
| emmc_cdata3 | I/O       | IO_FLASHd3_EMMCd3_SFCsio3_GPIO1A3vccio0      | GRF_GPIO1A_IOMUX_L[15:12]<br>=4'b10 |
| emmc_cdata4 | I/O       | IO_FLASHd4_EMMCd4_SFCCsn0_GPIO1A4vccio0      | GRF_GPIO1A_IOMUX_H[3:0]<br>=4'b10   |
| emmc_cdata5 | I/O       | IO_FLASHd5_EMMCd5_GPIO1A5vccio0              | GRF_GPIO1A_IOMUX_H[7:4]<br>=4'b10   |
| emmc_cdata6 | I/O       | IO_FLASHd6_EMMCd6_GPIO1A6vccio0              | GRF_GPIO1A_IOMUX_H[11:8]<br>=4'b10  |
| emmc_cdata7 | I/O       | IO_FLASHd7_EMMCd7_GPIO1A7vccio0              | GRF_GPIO1A_IOMUX_H[15:12]<br>=4'b10 |
| emmc_pwren  | O         | IO_FLASHcs0_EMMCPwren_GPIO1B0vccio0          | GRF_GPIO1B_IOMUX_L[3:0]<br>=4'b10   |
| emmc_rstn   | O         | IO_FLASHale_EMMCrstn_GPIO1B3vccio0           | GRF_GPIO1B_IOMUX_L[15:12]<br>=4'b10 |

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

## 3.6 Application Notes

### 3.6.1 Card-Detect and Write-Protect Mechanism

Following figure illustrates how the SD/MMC card detection and write-protect signals are connected. Most of the SD/MMC sockets have card-detect pins. When no card is present, card\_detect\_n is 1 due to the pull-up. When the card is inserted, the card-detect pin is shorted to ground, which makes card\_detect\_n go to 0. Similarly in SD cards, when the write-protect switch is toward the left, it shorts the write\_protect port to ground.



Fig. 3-9 SD/MMC Card-Detect and Write-Protect

### 3.6.2 SD/MMC Termination Requirement

Following Figure illustrates the SD/MMC termination requirements, which is required to pull up ccmd and cdata lines on the device bus. The recommended specification for pull-up on

the ccmd line (Rcmd) is 4.7K - 100K for MMC, and 10K - 100K for an SD. The recommended pull-up on the cdata line (Rdat) is 50K - 100K.



Fig. 3-10 SD/MMC Card Termination

### Rcmd and Rod Calculation

The SD/MMC card enumeration happens at a very low frequency – 100-400KHz. Since the MMC bus is a shared bus between multiple cards, during enumeration open-drive mode is used to avoid bus conflict. Cards that drive 0 win over cards that drive “z”. The pull-up in the command line pulls the bus to 1 when all cards drive “z”. During normal data transfer, the host chooses only one card and the card driver switches to push-pull mode.

For example, if enumeration is done at 400KHz and the total bus capacitance is 200 pf, the pull-up needed during enumeration is:

$$2.2 \text{ RC} = \text{rise-time} = 1/400\text{KHz}$$

$$\begin{aligned} R &= 1/(2.2 * C * 100\text{KHz}) \\ &= 1/(2.2 \times 200 \times 10^{12} \times 400 \times 10^{-12}) \\ &= 1/(17.6 \times 10^{-5}) \\ &= 5.68\text{K} \end{aligned}$$

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 register is sufficient and there is no need for an additional ROD pull-up during enumeration. You should also ensure the effective pull-up will not violate the I<sub>OL</sub> 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}$$

$$\begin{aligned} R &= 1/(2.2 * C * 100\text{KHz}) \\ &= 1/(2.2 \times 20 \times 10^{12} \times 400 \times 10^{-12}) \\ &= 1/(1.76 \times 10^{-5}) \\ &= 56.8\text{K} \end{aligned}$$

Therefore, a fixed 56.8K permanent Rcmd is sufficient in SD mode to enumerate the cards. The driver of the SD/MMC on the “command” port needs to be only a push-pull driver.

During enumeration, the SD/MMC emulates an open-drain driver by driving only a 0 or a “z” by controlling the ccmd\_out and cc当地\_out\_en signals.

### 3.6.3 Software/Hardware Restriction

Before issuing a new data transfer command, the software should ensure that the card is not busy due to any previous data transfer command. Before changing the card clock frequency, the software must ensure that there are no data or command transfers in progress.

If the card is enumerated in SDR50, or DDR50 mode, then the application must program the use\_hold\_reg bit[29] in the SDMMC\_CMD register to 1'b0 (phase shift of cclk\_in\_drv = 0) or 1'b1 (phase shift of cclk\_in\_drv>0). If the card is enumerated in SDR12 or SDR25 mode, the application must program the use\_hold\_reg bit[29] in the SDMMC\_CMD register to 1'b1. This programming should be done for all data transfer commands and non-data commands

that are sent to the card. When the use\_hold\_reg bit is programmed to 1'b0, the Host Controller bypasses the Hold Registers in the transmit path. The value of this bit should not be changed when a Command or Data Transfer is in progress. For more details on using use\_hold\_reg and the implementation requirements for meeting the Card input hold time, refer to "Recommended Usage" in following table.

Table 3-11 Recommended Usage of use\_hold\_reg

| No. | Speed Mode   | use_hold_reg | cclk_in (MHz) | clk_in_drv (MHz) | clk_divider | Phase shift |
|-----|--------------|--------------|---------------|------------------|-------------|-------------|
| 1   | SDR104       | 1'b0         | 200           | 200              | 0           | 0           |
| 2   | SDR104       | 1'b1         | 200           | 200              | 0           | Tunable> 0  |
| 3   | SDR50        | 1'b0         | 100           | 100              | 0           | 0           |
| 4   | SDR50        | 1'b1         | 100           | 100              | 0           | Tunable> 0  |
| 5   | DDR50 (8bit) | 1'b0         | 100           | 100              | 1           | 0           |
| 6   | DDR50 (8bit) | 1'b1         | 100           | 100              | 1           | Tunable> 0  |
| 7   | DDR50 (4bit) | 1'b0         | 50            | 50               | 0           | 0           |
| 8   | DDR50 (4bit) | 1'b1         | 50            | 50               | 0           | Tunable> 0  |
| 9   | SDR25        | 1'b1         | 50            | 50               | 0           | Tunable> 0  |
| 10  | SDR12        | 1'b1         | 50            | 50               | 1           | Tunable> 0  |

To avoid glitches in the card clock outputs, the software should use the following steps when changing the card clock frequency:

1) Before disable the clocks, ensure that the card is not busy due to any previous data command. To determine this, check for 0 in bit9 of STATUS register.

2) Update the Clock Enable register to disable all clocks. To ensure completion of any previous command before this update, send a command to the CIU to update the clock registers by setting:

- start\_cmd bit
- "update clock registers only" bits
- "wait\_previous data complete" bit

Wait for the CIU to take the command by polling for 0 on the start\_cmd bit.

3) Set the start\_cmd bit to update the Clock Divider and/or Clock Source registers, and send a command to the CIU in order to update the clock registers; wait for the CIU to take the command.

4) Set start\_cmd to update the Clock Enable register in order to enable the required clocks and send a command to the CIU to update the clock registers; wait for the CIU to take the command.

In non-DMA mode, while reading from a card, the Data Transfer Over (SDMMC\_RINTSTS[3]) interrupt occurs as soon as the data transfer from the card is over. There still could be some data left in the FIFO, and the RX\_WMark interrupt may or may not occur, depending on the remaining bytes in the FIFO. Software should read any remaining bytes upon seeing the Data Transfer Over (DTO) interrupt. While using the external DMA interface for reading from a card, the DTO interrupt occurs only after all the data is flushed to memory by the DMA interface unit.

While writing to a card in external DMA mode, if an undefined-length transfer is selected by setting the Byte Count Register to 0, the DMA logic will likely request more data than it will send to the card, since it has no way of knowing at which point the software will stop the transfer. The DMA request stops as soon as the DTO is set by the CIU.

If the software issues a controller\_reset command by setting control register bit[0] to 1, all the CIU state machines are reset; the FIFO is not cleared. The DMA sends all remaining bytes to the host. In addition to a card-reset, if a FIFO reset is also issued, then:

- Any pending DMA transfer on the bus completes correctly
- DMA data read is ignored
- Write data is unknown(x)

Additionally, if dma\_reset is also issued, any pending DMA transfer is abruptly terminated.

When the DMA is used, the DMA controller channel should also be reset and reprogrammed. If any of the previous data commands do not properly terminate, then the software should issue the FIFO reset in order to remove any residual data, if any, in the FIFO. After asserting the FIFO reset, you should wait until this bit is cleared.

One data-transfer requirement between the FIFO and host is that the number of transfers should be a multiple of the FIFO data width (32bits). For example, you want to write only 15 bytes to an SD/MMC card (SDMMC\_BYTCNT), the host should write 16 bytes to the FIFO or program the DMA to do 16-byte transfers. The software can still program the Byte Count register to only 15, at which point only 15 bytes will be transferred to the card. Similarly, when 15 bytes are read from a card, the host should still read all 16 bytes from the FIFO. It is recommended that you not change the FIFO threshold register in the middle of data transfers.

### 3.6.4 Programming Sequence

#### 1. Initialization

Following figure illustrates the initialization flow.



Fig. 3-11 Host Controller Initialization Sequence

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 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 `cclk_out` according to SD/MMC specifications.
  - `ResponseTimeOut` = `0x64`
  - `DataTimeOut` = highest of one of the following:
    - $(10 * ((TAAC * Fop) + (100 * NSAC)))$
    - Host FIFO read/write latency from FIFO empty/full

- Set the debounce value to 25ms(default:0xffff) in host clock cycle units in the DEBNCE register.
- FIFO threshold value in bytes in the SDMMC\_FIFOTH register.

## 2. Enumerated Card Stack

The card stack does the following:

- Enumerates all connected cards
- Sets the RCA for the connected cards
- Reads card-specific information
- Stores card-specific information locally

Enumeration depends on the operating mode of the SD/MMC card; the card type is first identified and the appropriate card enumeration routine is called.

- 1) Check if the card is connected.
- 2) Clear the card type register to set the card width as a single bit. For the given card number, clear the corresponding bits in the card\_type register. Clear the register bit for a 1-bit, 4-bit bus width. For example, for card number=1, clear bit 0 and bit 16 of the card\_type register.
- 3) Set clock frequency to FOD=400KHz, maximum – Program clock divider0 (bits 0-7 in the CLKDIV register) value to one-half of the cclk\_in frequency divided by 400KHz. For example, if cclk\_in is 20MHz, then the value is  $20,000/(2*400)=25$ .
- 4) Identify the card type; that is, SD, MMC, or SDIO.
  - a. Send CMD5 first. If a response is received, then the card is SDIO
  - b. If not, send CMD8 with the following Argument
    - Bit[31:12] = 20'h0 //reserved bits
    - Bit[11:8] = 4'b0001 //VHS value
    - Bit[7:0] = 8'b10101010 //Preferred Check Pattern by SD2.0
  - c. If Response is received the card supports High Capacity SD2.0 then send ACMD41 with the following Argument
    - Bit[31] = 1'b0; //Reserved bits
    - Bit[30] = 1'b1; //High Capacity Status
    - Bit[29:24] = 6'h0; //Reserved bits
    - Bit[23:0] = Supported Voltage Range
  - d. If Response is received for ACMD41 then the card is SD. Otherwise the card is MMC.
  - e. If response is not received for initial CMD8 then card does not support High Capacity SD2.0, then issue CMD0 followed by ACMD41 with the following Argument
    - Bit[31] = 1'b0; //Reserved bits
    - Bit[30] = 1'b0; //High Capacity Status
    - Bit[29:24] = 6'h0; //Reserved bits
    - Bit[23:0] = Supported Voltage Range
- 5) Enumerate the card according to the card type.
- 6) Use a clock source with a frequency = Fod (that is, 400KHz) and use the following enumeration command sequence:
  - SD card – Send CMD0, CMD8, ACMD41, CMD2, CMD3.
  - MMC – Send CMD0, CMD1, CMD2, CMD3.

## 3. 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 disabled while switching off the power.

## 4. Clock Programming

The Host Controller supports one clock sources. The clock to an individual card can be enabled or disabled. Registers that support this are:

- SDMMC\_CLKDIV – Programs individual clock source frequency. SDMMC\_CLKDIV limited to 0 or 1 is recommended.

- SDMMC\_CLKSRC – Assign clock source for each card.
- SDMMC\_CLKENA – Enables or disables clock for individual card and enables low-power mode, which automatically stops the clock to a card when the card is idle for more than 8 clocks.

The Host Controller loads each of these registers only when the start\_cmd bit and the Update\_clk\_regs\_only bit in the SDMMC\_CMD register are set. When a command is successfully loaded, the Host Controller clears this bit, unless the Host Controller already has another command in the queue, at which point it gives an HLE(Hardware Locked Error). Software should look for the start\_cmd and the Update\_clk\_regs\_only bits, and should also set the wait\_prvdata\_complete bit to ensure that clock parameters do not change during data transfer. Note that even though start\_cmd is set for updating clock registers, the Host Controller does not raise a command\_done signal upon command completion.

The following shows how to program these registers:

- 1) Confirm that no card is engaged in any transaction; if there is a transaction, wait until it finishes.
- 2) Stop all clocks by writing xxxx0000 to the SDMMC\_CLKENA register. Set the start\_cmd, Update\_clk\_regs\_only, and wait\_prvdata\_complete bits in the SDMMC\_CMD register. Wait until start\_cmd is cleared or an HLE is set; in case of an HLE, repeat the command.
- 3) Program the SDMMC\_CLKDIV and SDMMC\_CLKSRC registers, as required. Set the start\_cmd, Update\_clk\_regs\_only, and wait\_prvdata\_complete bits in the SDMMC\_CMD register. Wait until start\_cmd is cleared or an HLE is set; in case of an HLE, repeat the command.
- 4) Re-enable all clocks by programming the SDMMC\_CLKENA register. Set the start\_cmd, Update\_clk\_regs\_only, and wait\_prvdata\_complete bits in the SDMMC\_CMD register. Wait until start\_cmd is cleared or an HLE is set; in case of an HLE, repeat the command.

## 5. No-Data Command With or Without Response Sequence

To send any non-data command, the software needs to program the SDMMC\_CMD register @0x2C and the SDMMC\_CMDARG register @0x28 with appropriate parameters. Using these two registers, the Host Controller forms the command and sends it to the command bus. The Host Controller reflects the errors in the command response through the error bits of the SDMMC\_RINTSTS register.

When a response is received – either erroneous or valid – the Host Controller sets the command\_done bit in the SDMMC\_RINTSTS register. A short response is copied in Response Register0, while long response is copied to all four response registers @0x30, 0x34, 0x38, and 0x3C. The Response3 register bit 31 represents the MSB, and the Response0 register bit 0 represents the LSB of a long response.

For basic commands or non-data commands, follow these steps:

- 1) Program the Command register @0x28 with the appropriate command argument parameter.
- 2) Program the Command register @0x2C with the settings in following table.

Table 3-12 Command Settings for No-Data Command

| Parameter            | Value         | Description                                                                              |
|----------------------|---------------|------------------------------------------------------------------------------------------|
| <b>Default</b>       |               |                                                                                          |
| start_cmd            | 1             | -                                                                                        |
| use_hold_reg         | 1/0           | Choose value based on speed mode being used; ref to "use_hold_reg" on SDMMC_CMD register |
| update_clk_regs_only | 0             | No clock parameters update command                                                       |
| data_expected        | 0             | No data command                                                                          |
| card number          | 0             | Actual card number (one controller only connect one card, the num is No. 0)              |
| cmd_index            | command-index | -                                                                                        |
| send_initialization  | 0             | Can be 1, but only for card reset commands, such as                                      |

| Parameter              | Value | Description                                                                                                                                                                                                                                           |
|------------------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                        |       | 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                                                                                                                                                                                                    |

- 1) Wait for command acceptance by host. The following happens when the command is loaded into the Host Controller:
  - Host Controller accepts the command for execution and clears the start\_cmd bit in the SDMMC\_CMD register, unless one command is in process, at which point the Host Controller can load and keep the second command in the buffer.
  - If the Host Controller is unable to load the command – that is, a command is already in progress, a second command is in the buffer, and a third command is attempted – then it generates an HLE (hardware-locked error).
- 2) Check if there is an HLE.
- 3) Wait for command execution to complete. After receiving either a response from a card or response timeout, the Host Controller sets the command\_done bit in the SDMMC\_RINTSTS register. Software can either poll for this bit or respond to a generated interrupt.
- 4) Check if response\_timeout error, response\_CRC error, or response error is set. This can be done either by responding to an interrupt raised by these errors or by polling bits 1, 6, and 8 from the SDMMC\_RINTSTS register @0x44. If no response error is received, then the response is valid. If required, the software can copy the response from the response registers @0x30-0x3C.

Software should not modify clock parameters while a command is being executed.

## 6. Data Transfer Commands

Data transfer commands transfer data between the memory card and the Host Controller. To send a data command, the Host Controller needs a command argument, total data size, and block size. Software can receive or send data through the FIFO.

Before a data transfer command, software should confirm that the card is not busy and is in a transfer state, which can be done using the CMD13 and CMD7 commands, respectively. For the data transfer commands, it is important that the same bus width that is programmed in the card should be set in the card type register @0x18.

The Host Controller generates an interrupt for different conditions during data transfer, which are reflected in the SDMMC\_RINTSTS register @0x44 as:

- 1) Data\_Transfer\_Over (bit 3) – When data transfer is over or terminated. If there is a response timeout error, then the Host Controller does not attempt any data transfer and the “Data Transfer Over” bit is never set.
- 2) Transmit\_FIFO\_Data\_request (bit 4) – FIFO threshold for transmitting data was reached; software is expected to write data, if available, in FIFO.

- 3) Receive\_FIFO\_Data\_request (bit 5) – FIFO threshold for receiving data was reached; software is expected to read data from FIFO.
- 4) Data starvation by Host timeout (bit 10) – FIFO is empty during transmission or is full during reception. Unless software writes data for empty condition or reads data for full condition, the Host Controller cannot continue with data transfer. The clock to the card has been stopped.
- 5) Data read timeout error (bit 9) – Card has not sent data within the timeout period.
- 6) Data CRC error (bit 7) – CRC error occurred during data reception.
- 7) Start bit error (bit 13) – Start bit was not received during data reception.
- 8) End bit error (bit 15) – End bit was not received during data reception or for a write operation; a CRC error is indicated by the card.

Conditions 6, 7, and 8 indicate that the received data may have errors. If there was a response timeout, then no data transfer occurred.

## 7. Single-Block or Multiple-Block Read

Steps involved in a single-block or multiple-block read are:

- 1) Write the data size in bytes in the SDMMC\_BYTCNT register @0x20.
- 2) Write the block size in bytes in the SDMMC\_BLKSIZ register @0x1C. The Host Controller expects data from the card in blocks of size SDMMC\_BLKSIZ each.
- 3) Program the SDMMC\_CMDARG register @0x28 with the data address of the beginning of a data read.
- 4) Program the Command register with the parameters listed in following table. For SD and MMC cards, use CMD17 for a single-block read and CMD18 for a multiple-block read. For SDIO cards, use CMD53 for both single-block and multiple-block transfers.

Table 3-13 Command Setting for Single or Multiple-Block Read

| Parameter              | Value         | Description                                                                              |
|------------------------|---------------|------------------------------------------------------------------------------------------|
| <b>Default</b>         |               |                                                                                          |
| start_cmd              | 1             | -                                                                                        |
| use_hold_reg           | 1/0           | Choose value based on speed mode being used; ref to "use_hold_reg" on SDMMC_CMD register |
| update_clk_regs_only   | 0             | No clock parameters update command                                                       |
| card number            | 0             | Actual card number (one controller only connect one card, the num is No.0)               |
| send_initialization    | 0             | Can be 1, but only for card reset commands, such as CMD0                                 |
| stop_abort_cmd         | 0             | Can be 1 for commands to stop data transfer, such as CMD12                               |
| send_auto_stop         | 0/1           | -                                                                                        |
| transfer_mode          | 0             | Block transfer                                                                           |
| read_write             | 0             | Read from card                                                                           |
| data_expected          | 1             | Data command                                                                             |
| response_length        | 0             | Can be 1 for R2(long) response                                                           |
| response_expect        | 1             | Can be 0 for commands with no response; for example, CMD0, CMD4, CMD15, and so on        |
| <b>User-selectable</b> |               |                                                                                          |
| cmd_index              | command-index | -                                                                                        |
| wait_prvdata_complete  | 1             | 0: Sends command immediately<br>1: Sends command after                                   |

| Parameter          | Value | Description                                                                                      |
|--------------------|-------|--------------------------------------------------------------------------------------------------|
|                    |       | previous data transfer ends                                                                      |
| check_response_crc | 1     | 0: Host Controller should not check response CRC<br>1: Host Controller should check response CRC |

After writing to the SDMMC\_CMD register, the Host Controller starts executing the command; when the command is sent to the bus, the command\_done interrupt is generated.

- Software should look for data error interrupts; that is, bits 7, 9, 13, and 15 of the SDMMC\_RINTSTS register. If required, software can terminate the data transfer by sending a STOP command.
- Software should look for Receive\_FIFO\_Data\_request and/or data starvation by host timeout conditions. In both cases, the software should read data from the FIFO and make space in the FIFO for receiving more data.
- When a Data\_Transfer\_Over interrupt is received, the software should read the remaining data from the FIFO.

## 8. 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 SDMMC\_BLKSIZ register @0x1C; the Host Controller sends data in blocks of size SDMMC\_BLKSIZ each.
- 3) Program SDMMC\_CMDARG register @0x28 with the data address to which data should be written.
- 4) Write data in the FIFO; it is usually best to start filling data the full depth of the FIFO.
- 5) Program the Command register with the parameters listed in following table.

Table 3-14 Command Settings for Single or Multiple-Block Write

| Parameter              | Value | Description                                                                              |
|------------------------|-------|------------------------------------------------------------------------------------------|
| <b>Default</b>         |       |                                                                                          |
| start_cmd              | 1     | -                                                                                        |
| use_hold_reg           | 1/0   | Choose value based on speed mode being used; ref to "use_hold_reg" on SDMMC_CMD register |
| update_clk_regs_only   | 0     | No clock parameters update command                                                       |
| card number            | 0     | Actual card number (one controller only connect one card, the num is No. 0)              |
| send_initialization    | 0     | Can be 1, but only for card reset commands, such as CMD0                                 |
| stop_abort_cmd         | 0     | Can be 1 for commands to stop data transfer, such as CMD12                               |
| send_auto_stop         | 0/1   | -                                                                                        |
| transfer_mode          | 0     | Block transfer                                                                           |
| read_write             | 1     | Write to card                                                                            |
| data_expected          | 1     | Data command                                                                             |
| response_length        | 0     | Can be 1 for R2(long) response                                                           |
| response_expect        | 1     | Can be 0 for commands with no response; for example, CMD0, CMD4, CMD15, and so on        |
| <b>User-selectable</b> |       |                                                                                          |

| Parameter             | Value         | Description                                                                                      |
|-----------------------|---------------|--------------------------------------------------------------------------------------------------|
| cmd_index             | command-index | -                                                                                                |
| wait_prvdata_complete | 1             | 0: Sends command immediately<br>1: Sends command after previous data transfer ends               |
| check_response_crc    | 1             | 0: Host Controller should not check response CRC<br>1: Host Controller should check response CRC |

After writing to the SDMMC\_CMD register, Host Controller starts executing a command; when the command is sent to the bus, a command\_done interrupt is generated.

- Software should look for data error interrupts; that is, for bits 7, 9, and 15 of the SDMMC\_RINTSTS register. If required, software can terminate the data transfer by sending the STOP command.
- Software should look for Transmit\_FIFO\_Data\_Request and/or timeout conditions from data starvation by the host. In both cases, the software should write data into the FIFO.
- When a Data\_Transfer\_Over interrupt is received, the data command is over. For an open-ended block transfer, if the byte count is 0, the software must send the STOP command. If the byte count is not 0, then upon completion of a transfer of a given number of bytes, the Host Controller should send the STOP command, if necessary. Completion of the AUTO-STOP command is reflected by the Auto\_command\_done interrupt – bit 14 of the SDMMC\_RINTSTS register. A response to AUTO\_STOP is stored in SDMMC\_RESP1 @0x34.

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

## 10. Stream Write

A stream write is exactly like the block write mentioned in "Single-Block or Multiple-Block Write", except for the following bits in the Command register:

```
transfer_mode = 1;//Stream transfer
cmd_index = CMD11;
```

In a stream transfer, if the byte count is 0, then the software must send the STOP command. If the byte count is not 0, then when a given number of bytes completes a transfer, the Host Controller sends the STOP command. Completion of this AUTO\_STOP command is reflected by the Auto\_command\_done interrupt. A response to an AUTO\_STOP is stored in the SDMMC\_RESP1 register@0x34.

A stream transfer is allowed for only a single-bit bus width.

## 11. Packed Commands

In order to reduce overhead, read and write commands can be packed in groups of commands—either all read or all write—that transfer the data for all commands in the group in one transfer on the bus.

Packed commands can be of two types:

- Packed Write: CMD23 →CMD25
- Packed Read: CMD23 → CMD25 → CMD23 → CMD18

Packed commands are put in packets by the application software and are transparent to the core.

## 12. Sending Stop or Abort in Middle of Transfer

The STOP command can terminate a data transfer between a memory card and the Controller, while the ABORT command can terminate an I/O data transfer for only the SDIO\_IOONLY and SDIO\_COMBO cards.

- Send STOP command – Can be sent on the command line while a data transfer is in progress; this command can be sent at any time during a data transfer.

You can also use an additional setting for this command in order to set the Command

register bits (5-0) to CMD12 and set bit 14 (stop\_abort\_cmd) to 1. If stop\_abort\_cmd is not set to 1, the Controller does not know that the user stopped a data transfer. Reset bit 13 of the Command register (wait\_prvdata\_complete) to 0 in order to make the Controller send the command at once, even though there is a data transfer in progress.

- Send ABORT command – Can be used with only an SDIO\_IOONLY or SDIO\_COMBO card. To abort the function that is transferring data, program the function number in ASx bits (CCCR register of card, address 0x06, bits (0-2) using CMD52.

### **13. Read\_Wait Sequence**

Read\_wait is used with only the SDIO card and can temporarily stall the data transfer—either from function or memory—and allow the host to send commands to any function within the SDIO device. The host can stall this transfer for as long as required. The Host Controller provides the facility to signal this stall transfer to the card. The steps for doing this are:

- 1) Check if the card supports the read\_wait facility; read SRW (bit 2) of the CCCR register @0x08. If this bit is 1, then all functions in the card support the read\_wait facility. Use CMD52 to read this bit.
- 2) If the card supports the read\_wait signal, then assert it by setting the read\_wait (bit 6) in the SDMMC\_CTRL register @0x00.
- 3) Clear the read\_wait bit in the SDMMC\_CTRL register.

### **14. Controller/DMA/FIFO Reset Usage**

- Controller reset – Resets the controller by setting the controller\_reset bit (bit 0) in the SDMMC\_CTRL register; this resets the CIU and state machines, and also resets the BIU-to-CIU interface. Since this reset bit is self-clearing, after issuing the reset, wait until this bit is cleared.
- FIFO reset - Resets the FIFO by setting the fifo\_reset bit (bit 1) in the SDMMC\_CTRL register; this resets the FIFO pointers and counters of the FIFO. Since this reset bit is self-clearing, after issuing the reset, wait until this bit is cleared.

In external DMA transfer mode, even when the FIFO pointers are reset, if there is a DMA transfer in progress, it could push or pop data to or from the FIFO; the DMA itself completes correctly. In order to clear the FIFO, the software should issue an additional FIFO reset and clear any FIFO underrun or overrun errors in the SDMMC\_RAWINTS register caused by the DMA transfers after the FIFO was reset.

### **15. Card Read Threshold**

When an application needs to perform a Single or Multiple Block Read command, the application must program the SDMMC\_CARDTHRCTL register with the appropriate Card Read Threshold size (CardRdThreshold) and set the Card Read Threshold Enable (CardRdThrEnable) bit to 1'b1. This additional programming ensures that the Host controller sends a Read Command only if there is space equal to the CardRdThreshold available in the Rx FIFO. This in turn ensures that the card clock is not stopped in the middle of a block of data being transmitted from the card. The Card Read Threshold can be set to the block size of the transfer, which guarantees that there is a minimum of one block size of space in the RxFIFO before the controller enables the card clock. The Card Read Threshold is required when the Round Trip Delay is greater than 0.5cclk\_in period.

### **16. Error Handling**

The Host Controller implements error checking; errors are reflected in the SDMMC\_RAWINTS register@0x44 and can be communicated to the software through an interrupt, or the software can poll for these bits. Upon power-on, interrupts are disabled (int\_enable in the SDMMC\_CTRL register is 0), and all the interrupts are masked (bits 0-31 of the SDMMC\_INTMASK register; default is 0).

Error handling:

- Response and data timeout errors – For response timeout, software can retry the command. For data timeout, the Host Controller has not received the data start bit – either for the first block or the intermediate block – within the timeout period, so software can either retry the whole data transfer again or retry from a specified block onwards. By reading the contents of the SDMMC\_TCBCNT later, the software can decide how many bytes remain to be copied.
- Response errors – Set when an error is received during response reception. In this case,

- the response that copied in the response registers is invalid. Software can retry the command.
- Data errors – Set when error in data reception are observed; for example, data CRC, start bit not found, end bit not found, and so on. These errors could be set for any block-first block, intermediate block, or last block. On receipt of an error, the software can issue a STOP or ABORT command and retry the command for either whole data or partial data.
  - Hardware locked error – Set when the Host Controller cannot load a command issued by software. When software sets the start\_cmd bit in the SDMMC\_CMD register, the Host Controller tries to load the command. If the command buffer is already filled with a command, this error is raised. The software then has to reload the command.
  - FIFO underrun/overrun error – If the FIFO is full and software tries to write data in the FIFO, then an overrun error is set. Conversely, if the FIFO is empty and the software tries to read data from the FIFO, an underrun error is set. Before reading or writing data in the FIFO, the software should read the fifo\_empty or fifo\_full bits in the Status register.
  - Data starvation by host timeout – Raised when the Host Controller is waiting for software intervention to transfer the data to or from the FIFO, but the software does not transfer within the stipulated timeout period. Under this condition and when a read transfer is in process, the software should read data from the FIFO and create space for further data reception. When a transmit operation is in process, the software should fill data in the FIFO in order to start transferring data to the card.
  - CRC Error on Command – If a CRC error is detected for a command, the CE-ATA device does not send a response, and a response timeout is expected from the Host Controller. The ATA layer is notified that an MMC transport layer error occurred.

*Notes: During a multiple-block data transfer, if a negative CRC status is received from the device, the data path signals a data CRC error to the BIU by setting the data CRC error bit in the SDMMC\_RINTSTS register. It then continues further data transmission until all the bytes are transmitted.*

### 3.6.5 Voltage Switching

The Host Controller supports SD 3.0 Ultra High Speed (UHS-1) and is capable of voltage switching in SD-mode, which can be applied to SD High-Capacity (SDHC) and SD Extended Capacity (SDXC) cards. UHS-1 supports only 4-bit mode.

However, whether the IO voltage of 1.8v supported or not is depended on the SoC design. SD 3.0 UHS-1 supports the following transfer speed modes for UHS-50 and/or UHS-104 cards:

- DS – default-speed up to 25MHz, 3.3V signaling
- HS – high-speed up to 50MHz, 3.3V signaling
- SDR12 – SDR up to SDR 25MHz, 1.8V signaling
- SDR25 – SDR up to 50MHz, 1.8V signaling
- SDR50 – SDR up to 100MHz, 1.8V signaling
- DDR50 – DDR up to 50MHz, 1.8V signaling

Voltage selection can be done in only SD mode. The first CMD0 selects the bus mode-either SD mode or SPI mode. The card must be in SD mode in order for 1.8V signaling mode to apply, during which time the card cannot be switched to SPI mode or 3.3V signaling without a power cycle.

If the System BIOS in an embedded system already knows that it is connected to an SD 3.0 card, then the driver programs the Controller to initiate ACMD41. The software knows from the response of ACMD41 whether or not the card supports voltage switching to 1.8V.

- If bit 32 of ACMD41 response is 1'b1: card supports voltage switching and next command-CMD11-invokes voltage switching sequence. After CMD11 is started, the software must program the IO voltage selection register based on the soc architecture.
- If bit 32 of ACMD41 response is 1'b0: card does not support voltage switching and CMD11 should not be started.

If the card and host controller accept voltage switching, then they support UHS-1 modes of data transfer. After the voltage switch to 1.8V, SDR12 is the default speed.

Since the UHS-1 can be used in only 4-bit mode, the software must start ACMD6 and change the card data width to 4-bit mode; ACMD6 is driven in any of the UHS-1 speeds. If

the host wants to select the DDR mode of data transfer, then the software must program the SDMMC\_DDR\_REG register in the CSR space with the appropriate card number. To choose from any of the SDR or DDR modes, appropriate values should be programmed in the SDMMC\_CLKDIV register.

### 1. Voltage Switch Operation

The Voltage Switch operation must be performed in SD mode only.



Fig. 3-12 Voltage Switching Command Flow Diagram

The following outlines the steps for the voltage switch programming sequence

- 1) Software Driver starts CMD0, which selects the bus mode as SD.
- 2) After the bus is in SD card mode, CMD8 is started in order to verify if the card is compatible with the SD Memory Card Specification, Version 2.00. CMD8 determines if the card is capable of working within the host supply voltage specified in the VHS (19:16) field of the CMD; the card supports the current host voltage if a response to CMD8 is received.
- 3) ACMD 41 is started. The response to this command informs the software if the card supports voltage switching; bits 38, 36, and 32 are checked by the card argument of ACMD41; refer to following figure.

| 47 | 46 | 45-40  | 39      | 38     | 37      | 36     | 35-33          | 32      | 31-16     | 15-08          | 07-01  | 00 |
|----|----|--------|---------|--------|---------|--------|----------------|---------|-----------|----------------|--------|----|
| S  | D  | Index  | Busy 31 | HCS 30 | (FB) 29 | XPC 28 | Reserved 27-25 | S18R 24 | OCR 23-08 | Reserved 07-00 | CRC7   | E  |
| 0  | 1  | 101001 | 0       | X      | 0       | X      | 000            | X       | xxxxh     | 0000000        | xxxxxx | 1  |

Annotations below the table:

- Host Capacity Support**  
0b: SDSC-only Host  
1b: SDHC or SDXC supported
- SCXC Power Control**  
0b: Power saving  
1b: Maximum performance
- S18R: Switching to 1.8V Request**  
0b: Use current signal voltage  
1b: Switch to 1.8V signal voltage

Fig. 3-13 ACMD41 Argument

- Bit 30 informs the card if host supports SDHC/SDXC or not; this bit should be set to 1'b1.
- Bit 28 can be either 1 or 0.
- Bit 24 should be set to 1'b1, indicating that the host is capable of voltage switching; refer to following figure.



Fig. 3-14 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".

## 2. Voltage Switch Normal Scenario



Fig. 3-15 Voltage Switch Normal Scenario

- The host programs SDMMC\_CLKENA—cclk\_low\_power register—with zero (0) for the corresponding card, which makes the host controller move to high-power mode. The application should start a timer with a recommended value of 2ms; this value of 2 ms is determined as below: Total 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  

$$\text{Total} = 48+48 + 60 = 160$$
  
 Minimum frequency during enumeration is 100 KHz; that is, 10us  

$$\text{Total time} = 160 * 10\mu\text{s} = 1600\mu\text{s} = 1.6\text{ms} \sim 2\text{ms}$$
- The host issues CMD11 to start the voltage switch sequence. Set bit 28 to 1'b1 in CMD when setting CMD11; for more information on setting bits, refer to "Boot Operation".
- The card returns R1 response; the host controller does not generate cmd\_done interrupt on receiving R1 response.
- The card drives CMD and DAT [3:0] to low immediately after the response. The host controller generates interrupt (VOLT\_SWITCH\_INT) once the CMD or DAT [3:0] line goes low. The application should wait for this interrupt. If the 2ms timer expires without an interrupt (CMD/DAT lines going low), do a power cycle.

Note: Before doing a power cycle, switch off the card clock by programming SDMMC\_CLKENA register  
 Proceed to step (5) on getting an interrupt (VOLT\_SWITCH\_INT).

Note: This interrupt must be cleared once this interrupt is received. Additionally, this interrupt should not be

masked during the voltage switch sequence.

If the timer expires without interrupt (CMD/DAT lines going low), perform a power cycle.

Proceed to step (5) on interrupt.

- 1) Program the SDMMC\_CLKENA, cclk\_enable register, with 0 for the corresponding card; the host stops supplying SDCLK.
- 2) Program Voltage register to the required values for the corresponding card. The application should start a timer > 5ms.
- 3) After the 5ms timer expires, the host voltage regulator is stable. Program SDMMC\_CLKENA, cclk\_enable register, with 1 for the corresponding card; the host starts providing SDCLK at 1. 8V; this can be at zero time after Voltage register has been programmed. When the SDMMC\_CLKENA register is programmed, the application should start another timer > 1ms.
- 4) By detecting SDCLK, the card drives CMD to high at 1. 8V for at least one clock and then stops driving (tri-state); CMD is triggered by the rising edge of SDCLK (SDR timing).
- 5) If switching to 1. 8V signaling is completed successfully, the card drives DAT [3:0] to high at 1. 8V for at least one clock and then stops driving (tri-state); DAT [3:0] is triggered by the rising edge of SDCLK (SDR timing). DAT[3:0] must be high within 1ms from the start of SDCLK.
- 6) The host controller generates a voltage switch interrupt (VOLT\_SWITCH\_INT) and a command done (CD) interrupt once the CMD and DAT[3:0] lines go high. The application should wait for this interrupt to confirm CMD and DAT lines going high before the 1ms timer is done.

If the timer expires without the voltage switch interrupt (VOLT\_SWITCH\_INT), a power cycle should be performed. Program the SDMMC\_CLKENA register to stop the clock for the corresponding card number. Wait for the cmd\_done (CD) interrupt. Proceed for normal operation on interrupt. After the sequence is completed, the host and the card start communication in SDR12 timing.

### 3. Voltage Switch Error Scenario



Fig. 3-16 Voltage Switch Error Scenario

- 1) If the interrupt (VOLT\_SWITCH\_INT) does not come, then the 2 ms timer should time out and a power cycle should be initiated.

*Note: Before performing a power cycle, switch off the card clock by programming SDMMC\_CLKENA register; no cmd\_done (CD) interrupt is generated.*

Additionally, if the card detects a voltage error at any point in between steps (5) and (7) in the card keeps driving DAT[3:0] to low until card power off.

- 2) CMD can be low or tri-state.
- 3) The host controller generates a voltage switch interrupt once the CMD and DAT[3:0] lines go high. The application should check for an interrupt to confirm CMD and DAT lines going high before the 1 ms timer is done.

If the 1 ms timer expires without interrupt (VOLT\_SWITCH\_INT) and cmd\_done (CD), a power cycle should be performed. Program the SDMMC\_CLKENA register to stop SDCLK of the corresponding card. Wait for the cmd\_done interrupt. Proceed for normal operation on interrupt.

- 4) If DAT[3:0] is low, the host drives SDCLK to low and then stops supplying the card power.

*Note: The card checks voltages of its own regulator output and host signals to ensure they are less than 2. 5V. Errors are indicated by (1) and (2).*

- If voltage switching is accepted by the card, the default speed is SDR12.
- Command Done is given:
  - If voltage switching is properly done, CMD and DAT line goes high.
  - If switching is not complete, the 1ms timer expires, and the card 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.

### **3.6.6 Back-End Power**

Each device needs one bit to control the back-end power supply for an embedded device; this bit does not control the VDDH of the host controller. A back\_end\_power register enables software programming for back-end power. The value on this register is output to the back\_end\_power signal, which can be used to switch power on and off the embedded device.

### **3.6.7 DDR Operation**

#### **1. 4-bit DDR Programming Sequence**

DDR programming should be done only after the voltage switch operation has completed.

The following outlines the steps for the DDR programming sequence:

- 1) Once the voltage switch operation is complete, the user must program voltage selection register to the required values for the corresponding card.
- To start a card to work in DDR mode, the application must program a bit of the newly defined SDMMC\_UHS\_REG[16] register with a value of 1'b1.
- The bit that the user programs depends on which card is to be accessed in DDR mode.
- 2) To move back to SDR mode, a power cycle should be run on the card—putting the card in SDR12 mode—and only then should SDMMC\_UHS\_REG[16] be set back to 1'b0 for the appropriate card.

#### **2. 8-bit DDR Programming Sequence**

The following outlines the steps for the 8-bit DDR programming sequence:

- 1) The cclk\_in signal should be twice the speed of the required cclk\_out. Thus, if the cclk\_out signal is required to be 50 MHz, the cclk\_in signal should be 100 MHz.
- 2) The CLKDIV register should always be programmed with a value higher than zero (0); that is, a clock divider should always be used for 8-bit DDR mode.
- 3) The application must program the SDMMC\_UHS\_REG[16] register (DDR\_REG bits) by assigning it with a value of 1 for the bit corresponding to the card number; this causes the selected card to start working in DDR mode.
- 4) Depending on the card number, the SDMMC\_CTYPE [31:16] bits should be set in order to make the host work in the 8-bit mode.

#### **3. eMMC4.5 DDR START Bit**

The eMMC4.5 changes the START bit definition in the following manner:

- 1) Receiver samples the START bit on the rising edge.
- 2) On the next rising edge after sampling the START bit, the receiver must sample the data.
- 3) Removes requirement of the START bit and END bit to be high for one full cycle.

*Notes: The Host Controller does not support a START bit duration higher than one clock cycle. START bit durations of one or less than one clock cycle are supported and can be defined at the time of startup by programming the EMMC\_DDR\_REG register.*

Following figure illustrates cases for the definition change of the START bit with eMMC4.5; it also illustrates how some of these cases can fail in sampling when higher-value delays are considered for I/O PADs.



Fig. 3-17 CASES for eMMC 4.5 START bit

#### 4. Reset Command/Moving from DDR50 to SDR12

To reset the mode of operation from DDR50 to SDR12, the following sequence of operations has to be done by the application:

- 1) Issue CMD0.

When CMD0 is received, the card changes from DDR50 to SDR12.

- 2) Program the SDMMC\_CLKDIV register with an appropriate value.

- 3) Set DDR\_REG to 0.

*Note: The Voltage register should not be programmed to 0 while switching from DDR50 to SDR12, since the card is still operating in 1.8V mode after receiving CMD0.*

#### 3.6.8 H/W Reset Operation

When the RST\_n signal goes low, the card enters a pre-idle state from any state other than the inactive state.

##### H/W Reset Programming Sequence

The following outlines the steps for the H/W reset programming sequence:

- 11) Program CMD12 to end any transfer in process.
- 12) Wait for DTO, even if no response is sent back by the card.
- 13) Set the following resets:
  - DMA reset-SDMMC\_CTRL[2]
  - FIFO reset -SDMMC\_CTRL[1] bits
- Note: The above steps are required only if a transfer is in process.*
- 14) 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.
- 15) Wait for minimum of 1  $\mu\text{s}$  or cclk\_in period, whichever is greater
- 16) After a minimum of 1  $\mu\text{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.
- 17) The application can program a new CMD only after a minimum of 200  $\mu\text{s}$  after the de-assertion of the RST\_n signal, as per the MMC 4.41 standard.

*Note: For backward compatibility, the RST\_n signal is temporarily disabled in the card by default. The host may need to set the signal as either permanently enabled or permanently disabled before it uses the card.*

### 3.6.9 FBE Scenarios

An FBE occurs due to an AHB error response on the AHB bus. This is a system error, so the software driver should not perform any further programming to the Host. The only recovery mechanism from such scenarios is to do one of the following:

- Issue a hard reset by asserting the `reset_n` signal
- Do a program controller reset by writing to the `CTRL[0]` register

#### 1. FIFO Overflow and Underflow

During normal data transfer conditions, FIFO overflow and underflow will not occur. However if there is a programming error, then FIFO overflow/underflow can result. For example, consider the following scenarios.

- For transmit: PBL=4, Tx watermark = 1. For the above programming values, if the FIFO has only one location empty, it issues a `dma_req` to IDMAC FSM. Due to PBL value=4, the IDMAC FSM performs 4 pushes into the FIFO. This will result in a FIFO overflow interrupt.
- For receive: PBL=4, Rx watermark = 1. For the above programming values, if the FIFO has only one location filled, it issues a `dma_req` to IDMAC FSM. Due to PBL value=4, the IDMAC FSM performs 4 pops to the FIFO. This will result in a FIFO underflow interrupt.

The driver should ensure that the number of bytes to be transferred as indicated in the descriptor should be a multiple of 4bytes with respect to `H_DATA_WIDTH=32`. For example, if the `BYTCNT = 13`, the number of bytes indicated in the descriptor should be 16 for `H_DATA_WIDTH=32`.

#### 2. Programming of PBL and Watermark Levels

The DMAC performs data transfers depending on the programmed PBL and threshold values.

Table 3-15 PBL and Watermark Levels

| PBL (Number of transfers) | Tx/Rx Watermark Value        |
|---------------------------|------------------------------|
| 1                         | greater than or equal to 1   |
| 4                         | greater than or equal to 4   |
| 8                         | greater than or equal to 8   |
| 16                        | greater than or equal to 16  |
| 32                        | greater than or equal to 32  |
| 64                        | greater than or equal to 64  |
| 128                       | greater than or equal to 128 |
| 256                       | greater than or equal to 256 |

### 3.6.10 Variable Delay/Clock Generation

Variable delay mechanism for the `cclk_in_drv` is optional, but it can be useful in order to meet a range of hold-time requirements across modes. Variable delay mechanism for the `cclk_in_sample` is mandatory and is required to achieve the correct sampling point for data. `cclk_in/cclk_in_sample/ cclk_in_drv` is generated by Clock Generation Unit (CLKGEN) with variable delay mechanism, which includes Phase Shift Unit and Delay Line Unit selectable. The Phase Shift Unit can shift `cclk_in_sample/cclk_in_drv` by 0/90/180/270-degree relative to `cclk_in`, controlled by `sample_degree/drv_degree`.

The Delay Line Unit can shift `cclk_in_sample/cclk_in_drv` in the unit of 40ps~80ps for every delay element. The delay unit number is determined by `sample_delaynum/drv_delaynum`, and enabled by `sample_sel/drv_sel`.

`cclk_in` is generated by `cclkin` divided by 2. `cclk_in_drv` and `cclk_in_sample` clocks are phase-shifted with delayed versions of `cclk_in`. All clocks are recommended to have a 50% duty cycle; DDR modes must have 50% duty cycles.

The architecture is as follows.



Fig. 3-18 Clock Generation Unit

The control signals for different Host Controller instance are shown as follows:

Table 3-16 Configuration for SDMMC Clock Generation

| <b>Signal Name</b>                | <b>Source</b>                     | <b>Default</b> | <b>Description</b>                                                                                                                                                      |
|-----------------------------------|-----------------------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>init_state</code>           | <code>CRU_SDMMC_CON0[0]</code>    | 0              | Soft initial state for phase shift.                                                                                                                                     |
| <code>drv_degree[1:0]</code>      | <code>CRU_SDMMC_CON0[2:1]</code>  | 2              | Phase shift for <code>cclk_in_drv</code> .<br>0: 0-degree<br>1: 90-degree<br>2: 180-degree<br>3: 270-degree                                                             |
| <code>drv_delaynum[7:0]</code>    | <code>CRU_SDMMC_CON0[10:3]</code> | 0              | Element number in delay line for <code>cclk_in_drv</code>                                                                                                               |
| <code>drv_sel</code>              | <code>CRU_SDMMC_CON0[11]</code>   | 0              | <code>cclk_in_drv</code> source selection:<br>0: use clock after <code>phase_shift</code><br>1: use clock after <code>phase_shift</code> and <code>delay line</code>    |
| <code>sample_degree[1:0]</code>   | <code>CRU_SDMMC_CON1[2:1]</code>  | 0              | Phase shift for <code>cclk_in_sample</code> .<br>0: 0-degree<br>1: 90-degree<br>2: 180-degree<br>3: 270-degree                                                          |
| <code>sample_delaynum[7:0]</code> | <code>CRU_SDMMC_CON1[10:3]</code> | 0              | Element number in delay line for <code>cclk_in_sample</code>                                                                                                            |
| <code>sample_sel</code>           | <code>CRU_SDMMC_CON1[11]</code>   | 0              | <code>cclk_in_sample</code> source selection:<br>0: use clock after <code>phase_shift</code><br>1: use clock after <code>phase_shift</code> and <code>delay line</code> |

Table 3-17 Configuration for SDIO Clock Generation

| <b>Signal Name</b>              | <b>Source</b>                    | <b>Default</b> | <b>Description</b>                                                                                                                                                   |
|---------------------------------|----------------------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>init_state</code>         | <code>CRU_SDIO_CON0[0]</code>    | 0              | Soft initial state for phase shift.                                                                                                                                  |
| <code>drv_degree[1:0]</code>    | <code>CRU_SDIO_CON0[2:1]</code>  | 2              | Phase shift for <code>cclk_in_drv</code> .<br>0: 0-degree<br>1: 90-degree<br>2: 180-degree<br>3: 270-degree                                                          |
| <code>drv_delaynum[7:0]</code>  | <code>CRU_SDIO_CON0[10:3]</code> | 0              | Element number in delay line for <code>cclk_in_drv</code>                                                                                                            |
| <code>drv_sel</code>            | <code>CRU_SDIO_CON0[11]</code>   | 0              | <code>cclk_in_drv</code> source selection:<br>0: use clock after <code>phase_shift</code><br>1: use clock after <code>phase_shift</code> and <code>delay line</code> |
| <code>sample_degree[1:0]</code> | <code>CRU_SDIO_CON1[2:1]</code>  | 0              | Phase shift for <code>cclk_in_sample</code> .<br>0: 0-degree<br>1: 90-degree<br>2: 180-degree<br>3: 270-degree                                                       |

| <b>Signal Name</b>   | <b>Source</b>       | <b>Default</b> | <b>Description</b>                                                                                                  |
|----------------------|---------------------|----------------|---------------------------------------------------------------------------------------------------------------------|
| sample_delaynum[7:0] | CRU_SDIO_CON1[10:3] | 0              | Element number in delay line for cclk_in_sample                                                                     |
| sample_sel           | CRU_SDIO_CON1[11]   | 0              | cclk_in_sample source selection:<br>0: use clock after phase_shift<br>1: use clock after phase_shift and delay line |

Table 3-18 Configuration for EMMC Clock Generation

| <b>Signal Name</b>   | <b>Source</b>       | <b>Default</b> | <b>Description</b>                                                                                                  |
|----------------------|---------------------|----------------|---------------------------------------------------------------------------------------------------------------------|
| init_state           | CRU_EMMC_CON0[0]    | 0              | Soft initial state for phase shift.                                                                                 |
| drv_degree[1:0]      | CRU_EMMC_CON0[2:1]  | 2              | Phase shift for cclk_in_drv.<br>0: 0-degree<br>1: 90-degree<br>2: 180-degree<br>3: 270-degree                       |
| drv_delaynum[7:0]    | CRU_EMMC_CON0[10:3] | 0              | Element number in delay line for cclk_in_drv                                                                        |
| drv_sel              | CRU_EMMC_CON0[11]   | 0              | cclk_in_drv source selection:<br>0: use clock after phase_shift<br>1: use clock after phase_shift and delay line    |
| sample_degree[1:0]   | CRU_EMMC_CON1[2:1]  | 0              | Phase shift for cclk_in_sample.<br>0: 0-degree<br>1: 90-degree<br>2: 180-degree<br>3: 270-degree                    |
| sample_delaynum[7:0] | CRU_EMMC_CON1[10:3] | 0              | Element number in delay line for cclk_in_sample                                                                     |
| sample_sel           | CRU_EMMC_CON1[11]   | 0              | cclk_in_sample source selection:<br>0: use clock after phase_shift<br>1: use clock after phase_shift and delay line |

The following outlines the steps for clock generation sequence:

- 1) Assert init\_state to soft reset the CLKGEN.
- 2) Configure drv\_degree/sample\_degree.
- 3) If fine adjustment required, delay line can be used by configuring drv\_delaynum/sample\_delaynum and drv\_sel/sample\_sel.
- 4) Dis-assert init\_state to start CLKGEN.

### 3.6.11 Variable Delay Tuning

Tuning is defined by SD and MMC cards to determine the correct sampling point required for the host, especially for the speed modes SDR104 and HS200 where the output delays from the cards can be up to 2 UI. Tuning is required for other speed modes-such as DDR50-even though the output delay from the card is less than one cycle.

Command for tuning is different for different cards.

- SD Memory Card:
  - CMD19 – SD card for SDR50 and SDR104 speed modes. Tuning data is defined by card specifications.
  - CMD6 – SD card for speed modes not supporting CMD19. Tuning data is the 64byte SD status.
- Multimedia Card:
  - CMD21 – MMC card for HS200 speed mode. Tuning data is defined by card specifications.
  - CMD8 – MMC card for speed modes not supporting CMD21. Tuning data is 512 byte ExtCSD data.

The following is the procedure for variable delay tuning:

- 1) Set a phase shift of 0-degree on cclk\_in\_sample.
- 2) Send the Tuning command to the card; the card in turn sends an R1 response on the CMD line and tuning data on the DAT line.
- 3) If the host sees any of the errors—start bit error, data crc error, end bit error, data read time-out, response crc error, response error—then the sampling point is incorrect.
- 4) Send CMD12 to bring the host controller state machines to idle.
  - The card may treat CMD12 as an invalid command because the card has successfully sent the tuning data, and it cannot send a response.
  - The host controller may generate a response time-out interrupt that must be cleared by software.
- 5) Repeat steps 2) to 4) by increasing the phase shift value or delay element number on cclk\_in\_sample until the correct sampling point is received such that the host does not see any of the errors.
- 6) Mark this phase shift value as the starting point of the sampling window.
- 7) Repeat steps 2 to 4 by increasing the phase shift value or delay element number on cclk\_in\_sample until the host sees the errors starting to come again or the phase shift value reaches 360-degree.
- 8) Mark the last successful phase shift value as the ending point of the sampling window. A window is established where the tuning block is matched. For example, for a scenario where the tuning block is received correctly for a phase shift window of 90-degree and 180-degree, then an appropriate sampling point is established as 135-degree. Once a sampling point is established, no errors should be visible in the tuning block.

### 3.6.12 Package Command

In order to reduce overhead, read and write commands can be packed in groups of commands—either all read or all write—that transfer the data for all commands in the group in one transfer on the bus.

Packed commands can be of two types:

- Packed Write: CMD23 → CMD25
- Packed Read: CMD23 → CMD25 → CMD23 → CMD18

Packed commands are put in packets by the application software and are transparent to the core. For more information on packed commands, refer to the eMMC specification.

### 3.6.13 Card Detection Method

There are many methods for SDMMC/SDIO device detection.

- Method1: Using SDMMC\_CDETECT register, which is value on card\_detect\_n input port. 0 represents presence of card.
- Method2: Using card detection unit in Host Controller, outputting host interrupt. The card detection unit looks for any changes in the card-detect signals for card insertion or removal. It filters out the debounces associated with mechanical insertion or removal, and generates one interrupt to the host. You can program the debounce filter value in SDMMC\_DEBNCE [23:0]. Following figure illustrates the timing for card-detect signals.



Fig. 3-19 Card Detection Method 2

- Method3: Using card detection unit in GRF, outputting sdmmc\_detect\_dual\_edge\_int connecting to IRQ[91]. Similar to Method2, except that the debounce time is configurable by PMUGRF\_SDMMC\_DET; and the insertion/removal detection interrupt

can be enabled or cleared respectively. The detailed register information is:

Table 3-19 Register for SDMMC Card Detection Method 3

| Signal Name                              | Source                          | Default | Description                                                                  |
|------------------------------------------|---------------------------------|---------|------------------------------------------------------------------------------|
| sd_detectn_rise_ed<br>ge_irq_en          | PMUGRF_SIG_DETE<br>CT_CON[0]    | 0       | sdmmc detect_n signal rise edge interrupt enable.<br>1: enable<br>0: disable |
| sd_detect_fall_edge<br>_detect_en        | PMUGRF_SIG_DETE<br>CT_CON[1]    | 0       | sd_detect_falling_edge enable<br>0: disable<br>1: enable                     |
| sd_detect_rising_ed<br>ge_dectect_status | PMUGRF_SIG_DETE<br>CT_STATUS[0] | 0       | sd_detect_rising_edge status<br>0: disable<br>1: enable                      |
| sd_detect_fall_edge<br>_detect_status    | PMUGRF_SIG_DETE<br>CT_STATUS[1] | 0       | sd_detect_falling_edge status<br>0: disable<br>1: enable                     |
| sd_detect_rising_ed<br>ge_dectect_clr    | PMUGRF_SIG_DETE<br>CT_CLR[0]    | 0       | sd_detect_rising_edge clear<br>0: disable<br>1: enable                       |
| sd_detect_fall_edge<br>_detect_clr       | PMUGRF_SIG_DETE<br>CT_CLR[1]    | 0       | sd_detect_falling_edge clear<br>0: disable<br>1: enable                      |

- Method4: Using filtered card\_detect\_n with the debounce time PMUGRF\_SDMMC\_DET for interrupt source, connecting to IRQ [92] directly.



Fig. 3-20 Card Detection Method 4

### 3.6.14 SDMMC IOMUX With JTAG

The IO for sdmmc\_cdata2/sdmmc\_cdata3 is shared with jtag\_tck/jtag\_tms. The condition of usage for SDMMC or JTAG usage is as follows.

- If GRF\_SOC\_CON7[12](grf\_force\_jtag) is equal to 1 and sdmmc card is not detected within detection time(in the unit of XIN24M clock), the GPIOs are used for JTAG.
- Otherwise, the GPIOs' usage is defined by IOMUX configuration.

## Chapter 4 Process-Voltage-Temperature Monitor (PVTM)

### 4.1 Overview

The Process-Voltage-Temperature Monitor (PVTM) is used to monitor the chip performance variance caused by chip process, voltage and temperature.

PVTM supports the following features:

- A clock oscillation ring is integrated and used to generate a clock like signal, the frequency of this clock is determined by the cell delay value of clock oscillation ring circuit.
- A frequency counter is used to measure the frequency of the clock oscillation ring.
- Follow PVTM blocks are supported:
  - core\_pvtm, used near Cortex-A35
  - pmu\_pvtm, used near PMU

### 4.2 Block Diagram



Fig. 4-1 PVTM Block Diagram

The PVTM include two main blocks:

- RING OSC, it is composed with inverters with odd number, which is used to generate a clock. core\_pvtm support 3clock oscillation rings in RING OSC, and finally select a clock output by signal osc\_ring\_sel.
- Freq\_cal, it is used to measure the frequency of clock which generated from the RING SOC block.

### 4.3 Function Description

#### 4.3.1 Frequency Calculation

A clock is generated by the RING OSC, and a frequency fixed clock (24MHz) is used to calculate the cycles of the clock. Suppose the time period is 1s, then the clock period of RING OSC clock is  $T = 1/\text{clock\_counter(s)}$ , the cell delay value is  $T/2$ .

#### 4.3.2 Control Source and Result Destination

The pvtm is controlled by CRU and GRF, and the monitor result is geted by GRF. Following tables shows the PVTM control source and result destination.

Table 4-1 core\_pvtm control source and result destination

| Interface | Reset value | Control Source/Result Destination          |
|-----------|-------------|--------------------------------------------|
| xin24m    | 0x0         | CRU_CLKGATE17_CON[4], clock gating control |

| Interface       | Reset value | Control Source/Result Destination                          |
|-----------------|-------------|------------------------------------------------------------|
| resetn          | 0x1         | CRU_SOFRST1_CON[1], reverse connect to resetn, active high |
| start           | 0x0         | COREGRF_COREPVTM_CON0[0], active high                      |
| osc_ring_enable | 0x0         | COREGRF_COREPVTM_CON0[1], active high                      |
| osc_ring_sel    | 0x0         | COREGRF_COREPVTM_CON0[3:2]                                 |
| cal_cnt         | 0x0         | COREGRF_COREPVTM_CON1[31:0]                                |
| freq_done       | 0x0         | COREGRF_COREPVTM_STATUS0[0]                                |
| freq_cnt        | 0x0         | COREGRF_COREPVTM_STATUS1[31:0]                             |

Table 4-2 pmu\_pvtm control source and result destination

| Interface       | Reset value | Control Source/Result Destination                          |
|-----------------|-------------|------------------------------------------------------------|
| xin24m          | 0x0         | CRU_CLKGATE1_CON[4], clock gating control                  |
| resetn          | 0x1         | CRU_SOFRST6_CON[8], reverse connect to resetn, active high |
| start           | 0x1         | PMUGRF_PVTM_CON0[0], active high                           |
| osc_ring_enable | 0x1         | PMUGRF_PVTM_CON0[1], active high                           |
| cal_cnt         | 0x0         | PMUGRF_PVTM_CON1[31:0]                                     |
| freq_done       | 0x0         | PMUGRF_PVTM_STATUS0[0]                                     |
| freq_cnt        | 0x0         | PMUGRF_PVTM_STATUS1[31:0]                                  |

### 4.3.3 pmu\_pvtm usage

A clock divider from pmu\_pvtm oscillation ring is used in low power mode, which can replace the function of 32KHz clock source by configure CRU\_CLK\_SEL0[15:14]. The division factor is configured by PMUGRF\_PVTM\_CON0[7:2].

## 4.4 Application Notes

### 4.4.1 PVTM Usage Flow

1. Enable the frequency fixed clock xin24m.
2. Reset the pvtm.
3. Set osc\_ring\_enable '1' to enable the generated clock.
4. Set osc\_ring\_sel to select the clock oscillation ring(Only core\_b\_pvtm, core\_l\_pvtm, ddr\_pvtm and gpu\_pvtm need)
5. Configure the cal\_cnt to an appropriate value.
6. Set start '1' to calculate the cycles of the generated clock.
7. Wait the freq\_done is asserted, then get the value of freq\_cnt. The period of RING\_OSC clock is  $T = \text{cal\_cnt} * (\text{Period of 24MHz clock}) / \text{freq\_cnt}$ , the cell delay value is  $T/2$ .

## Chapter 5 Multi-format Video Encoder And Decoder

### 5.1 Overview

VPU\_Combo is composed by the H.265 (HEVC) decoder and the H.264 encoder/decoder to realize the high quality video decoding. VPU\_Combo is connected to the AHB bus through an AHB slave and the AXI bus through an AXI master. The register configuration is fed into the VPU\_Combo through the AHB slave interface while the stream data is transacted between DDR and VPU\_Combo through the AXI master interface.

To reduce the area, H.265 decoder and H.264 encoder/decoder not only share several pieces of the internal memories, but also share the bus master and slave interfaces. Therefore VPU\_Combo has no any possibility to have the H.265 video decoding and H.264 video encoding/decoding to work simultaneously.

In order to improve large data transaction performance, VPU embeds MMU (memory management unit) and supports the cacheable bus operation.

VPU\_Combo supports the next-generation video coding standard HEVC (High Efficiency Video Coding, aka H.265) full-HD decoding up to 60fps. With HEVC standard, the data compression ratio can be doubled compared to H.264/MEPG-4 at the same video quality or alternatively to provide substantially improved video at the same bit rate.

#### 5.1.1 Features

- Supports HEVC Main Profile up to Level 4.1 High Tier: 1920x1080@60 fps
  - MMU embedded
  - Supports frame timeout interrupt , frame finish interrupt and bitstream error interrupt
  - Supports RLC write mode, RLC mode and Normal Mode
- Supports decoding of the following standards
  - Error detection and concealment support for all video formats
  - Output data structure after decoder is YCbCr 4:2:0 semi-planar to have more efficient bus usage
  - H.264 up to HP level 4.1 : 1080p@60fps (1920x1088)
  - SVC: base layer only for Baseline/High Profile
  - MVC: Stereo High
  - MPEG-4: Simple Profile up to Level 6; Advanced Profile up to Level 5
  - MPEG-2: Main Profile up to High Level
  - MPEG-1: Main Profile up to High Level
  - H.263: Level 10-70 for Profile 0, and image size up to 720x576
  - JPEG: Baseline interleaved, and supports ROI (region of image) decode
  - RV: RV8, RV9, V10
  - VP7: up to version 3
  - VP8: version 2(webM)
  - WebP
  - For H.264, Image cropping not supported
- Built-in post processor in H.264 decoder supports:
  - Stand-alone mode: rotation, deinterlace, RGB conversion, scaling, dithering and alpha blending
  - Pipe-line mode: RGB conversion, scaling, dithering and alpha blending
- Supports encoding of the following standards:
  - H.264: up to HP level 4.1
  - JPEG: Baseline (DCT sequential)
- Built-in pre-processor in H.264 encoder supports:
  - Cropping, rotation, YCbCr conversion

## 5.2 Block Diagram



Fig. 5-1 VPU Combo in SOC



Fig. 5-2 VPU Combo Block Diagram

As shown in the figures above, CPU accesses to HEVC register bank through 32-bit AHB bus. Bitstream and compressed video data are fed into HEVC core though 128-bit AXI read channel, and after several steps of decoding process, decoded pictures are transferred to designated location in the DDR through 64-bit AXI write channel.

CPU accesses to H264encoder/decoder register bank through 32-bit AHB bus. Video data are fed into H.264 core though 64-bit AXI read channel, and after several steps of decoding process, process results are transferred to designated location in the DDR through 64-bit AXI write channel.

## **5.3 Function Description**

### **5.3.1 HEVC Standard**

High Efficiency Video Coding (HEVC) is a video compression standard, a successor to H.264/MPEG-4 AVC (Advanced Video Coding), that was jointly developed by the ISO/IEC Moving Picture Experts Group (MPEG) and ITU-T Video Coding Experts Group (VCEG) as ISO/IEC 23008-2 MPEG-H Part 2 and ITU-T H.265. MPEG and VCEG established a Joint Collaborative Team on Video Coding (JCT-VC) to develop the HEVC standard.

HEVC was designed to substantially improve coding efficiency compared to H.264/MPEG-4 AVC HP, i.e. to reduce bitrate requirements by half with comparable image quality, at the expense of increased computational complexity. HEVC was designed with the goal of allowing video content to have a data compression ratio of up to 1000:1. Depending on the application requirements HEVC encoders can trade off computational complexity, compression rate, robustness to errors, and encoding delay time. Two of the key features where HEVC was improved compared to H.264/MPEG-4 AVC was support for higher resolution video and improved parallel processing methods.

### **5.3.2 HEVC Coding Tools**

#### **1. Coding tree unit**

HEVC replaces macroblocks, which were used with previous standards, with Coding Tree Units (CTUs) which can use a larger block structures of up to 64x64 pixels and can better sub-partition the picture into variable sized structures. HEVC initially divides the picture into CTUs which can be 64x64, 32x32, or 16x16 with a larger pixel block size usually increasing the coding efficiency.

#### **2. Parallel processing tools**

Tiles allow for the picture to be divided up into a grid of rectangular regions that can independently be decoded/encoded and the main purpose of tiles is to allow for parallel processing. Tiles can be independently decoded and can even allow for random access to specific regions of a picture in a video stream.

Wavefront parallel processing (WPP) is when a slice is divided into rows of CTUs in which the first row is decoded normally but each additional row requires that decisions be made in the previous row. WPP has the entropy encoder use information from the preceding row of CTUs and allows for a method of parallel processing that may allow for better compression than tiles.

Tiles and WPP are allowed but are optional. If tiles are present they must be at least 64 pixels high and 256 pixels wide with a level specific limit on the number of tiles allowed. Slices can for the most part be decoded independently from each other with the main purpose of tiles being re-synchronization in case of data loss in the video stream. Slices can be defined as self-contained in that prediction is not made across slice boundaries. When in-loop filtering is done on a picture though information across slice boundaries may be required.[1] Slices are CTUs decoded in the order of the raster scan and different coding types can be used for slices such as I types, P types, or B types.

Dependent slices can allow for data related to tiles or WPP to be accessed more quickly by the system than if the entire slice had to be decoded.[1] The main purpose of dependent slices is to allow for low delay video encoding due to its lower latency.

#### **3. Entropy coding**

HEVC uses a context-adaptive binary arithmetic coding (CABAC) algorithm that is fundamentally similar to CABAC in H.264/MPEG-4 AVC. CABAC is the only entropy encoder method that is allowed in HEVC while there are two entropy encoder methods allowed by H.264/MPEG-4 AVC. CABAC and the entropy coding of transform coefficients in HEVC were designed for a higher throughput than H.264/MPEG-4 AVC. For instance, the number of context coded bins have been reduced by 8x and the CABAC bypass-mode has been

improved in terms of its design to increase throughput. Another improvement with HEVC is that the dependencies between the coded data has been changed to further increase throughput. Context modeling in HEVC has also been improved so that CABAC can better select a context that increases efficiency when compared to H.264/MPEG-4 AVC.

#### **4. Intra prediction**

HEVC specifies 33 directional modes for intra prediction compared to the 8 directional modes for intra prediction specified by H.264/MPEG-4 AVC. HEVC also specifies planar and DC intra prediction modes.[1] The intra prediction modes use data from neighboring prediction blocks that have been previously decoded.

#### **5. Motion compensation**

For the interpolation of fractional luma sample positions HEVC uses separable application of one-dimensional half-sample interpolation with an 8-tap filter or quarter-sample interpolation with a 7-tap filter while, in comparison, H.264/MPEG-4 AVC uses a two-stage process that first derives values at half-sample positions using separable one-dimensional 6-tap interpolation followed by integer rounding and then applies linear interpolation between values at nearby half-sample positions to generate values at quarter-sample positions.[1] HEVC has improved precision due to the longer interpolation filter and the elimination of the intermediate rounding error. For 4:2:0 video, the chroma samples are interpolated with separable one-dimensional 4-tap filtering to generate eighth-sample precision, while in comparison H.264/MPEG-4 AVC uses only a 2-tap bilinear filter (also with eighth-sample precision).

As in H.264/MPEG-4 AVC, weighted prediction in HEVC can be used either with uni-prediction (in which a single prediction value is used) or bi-prediction (in which the prediction values from two prediction blocks are combined).

#### **6. Motion vector prediction**

HEVC defines a signed 16-bit range for both horizontal and vertical motion vectors (MVs). This was added to HEVC at the July 2012 HEVC meeting with the mvLX variables. HEVC horizontal/vertical MVs have a range of -32768 to 32767 which given the quarter pixel precision used by HEVC allows for a MV range of -8192 to 8191.75 luma samples. This compares to H.264/MPEG-4 AVC which allows for a horizontal MV range of -2048 to 2047.75 luma samples and a vertical MV range of -512 to 511.75 luma samples.

HEVC allows for two MV modes which are Advanced Motion Vector Prediction (AMVP) and merge mode. AMVP uses data from the reference picture and can also use data from adjacent prediction blocks. The merge mode allows for the MVs to be inherited from neighboring prediction blocks. Merge mode in HEVC is similar to "skipped" and "direct" motion inference modes in H.264/MPEG-4 AVC but with two improvements. The first improvement is that HEVC uses index information to select one of several available candidates. The second improvement is that HEVC uses information from the reference picture list and reference picture index.

#### **7. Inverse transforms**

HEVC specifies four transform units (TUs) sizes of 4x4, 8x8, 16x16, and 32x32 to code the prediction residual. A CTB may be recursively partitioned into 4 or more TUs.[1] TUs use integer basis functions that are similar to the discrete cosine transform (DCT). In addition 4x4 luma transform blocks that belong to an intra coded region are transformed using an integer transform that is derived from discrete sine transform (DST). This provides a 1% bit rate reduction but was restricted to 4x4 luma transform blocks due to marginal benefits for the other transform cases. Chroma uses the same TU sizes as luma so there is no 2x2 transform for chroma.

## 8. Loop filters

HEVC specifies two loop filters that are applied sequentially, with the deblocking filter (DBF) applied first and the sample adaptive offset (SAO) filter applied afterwards. Both loop filters are applied in the inter-picture prediction loop, i.e. the filtered image is stored in the decoded picture buffer (DPB) as a reference for inter-picture prediction.

### 8.1 Deblocking filter

The DBF is similar to the one used by H.264/MPEG-4 AVC but with a simpler design and better support for parallel processing.[1] In HEVC the DBF only applies to a 8x8 sample grid while with H.264/MPEG-4 AVC the DBF applies to a 4x4 sample grid. DBF uses a 8x8 sample grid since it causes no noticeable degradation and significantly improves parallel processing because the DBF no longer causes cascading interactions with other operations. Another change is that HEVC only allows for three DBF strengths of 0 to 2. HEVC also requires that the DBF first apply horizontal filtering for vertical edges to the picture and only after that does it apply vertical filtering for horizontal edges to the picture. This allows for multiple parallel threads to be used for the DBF.

### 8.2 Sample adaptive offset

The SAO filter is applied after the DBF and is designed to allow for better reconstruction of the original signal amplitudes by applying offsets stored in a lookup table in the bitstream. Per CTB the SAO filter can be disabled or applied in one of two modes: edge offset mode or band offset mode. The edge offset mode operates by comparing the value of a sample to two of its eight neighbors using one of four directional gradient patterns. Based on a comparison with these two neighbors, the sample is classified into one of five categories: minimum, maximum, an edge with the sample having the lower value, an edge with the sample having the higher value, or monotonic. For each of the first four categories an offset is applied. The band offset mode applies an offset based on the amplitude of a single sample. A sample is categorized by its amplitude into one of 32 bands (histogram bins). Offsets are specified for four consecutive of the 32 bands, because in flat areas which are prone to banding artifacts, sample amplitudes tend to be clustered in a small range.[1][135] The SAO filter was designed to increase picture quality, reduce banding artifacts, and reduce ringing artifacts.

### 5.3.3 MMU

The MMU divides memory into 4KB pages, where each page can be individually configured. For each page the following parameters are specified:

- Address translation of virtual memory, this enables the processor to work using address that differ from the physical address in the memory system.
- The permitted types of accesses to that page. Each page can permit read, write, both, or none.

The MMU use 2-level page table structure:

1. The first level, the page directory consists of 1024 directory table entries(DTEs), each pointing to a page table.
2. The second level, the page table consists of 1024 page table entries(PTEs), each pointing to a page in memory.



Fig. 5-3 structure of two-level page table

### 5.3.4 HEVC Working Mode

There are three working modes to be selected for HEVC decoder: RLC Mode, RLC Write Mode, Normal Mode.

The key differences among three working modes are whether CABAC module and Post-CABAC module are involved into the hardware decoding process.

For RLC mode, CABAC are bypassed and the input bitstream to the Post-CABAC module should be already decoded.

For RLC write mode, the decoded results by CABAC are output to the DDR, and the following decoding processes are stopped.

As for the normal mode, all the modules are involved into the decoding process, and complete decoding results are output. Normally, this mode should be selected.

### 5.3.5 H.264 decoder

The input of the decoder is H.264 standard bit stream in either plain NAL unit format or byte stream format. The input format in use will be automatically detected. The H.264 video encoding allows the use of multiple reference pictures, which means that the decoding order of the pictures may be different from their display order. The decoder can perform internally the display reordering of the decoded pictures or it can skip this and output all the pictures as soon as they are decoded.

The decoder has two operating modes: in the primary mode the HW performs entropy decoding, and in the secondary mode SW performs entropy decoding. Secondary mode is used in H.264 ASO or Slice Group stream decoding.

External memory



Fig. 5-4 Dataflow of HW performs entropy decoding in video decoder

The dataflow of HW performs entropy decoding is as Fig. 5-4 shown. The decoder software (SW) starts decoding the first picture by parsing the stream headers (1). Software then setups the hardware control registers (picture size, stream start address etc.) and enables the hardware (2). Hardware decodes the picture by reading stream (3) and the reference pictures (required for inter picture decoding)(4) from the external memory. Hardware writes the decoded output picture to memory one macroblock at a time (5). When the picture has been fully decoded the hardware has run out of stream data, it gives an interrupt with a proper status flag and provides stream and address for software to continue and returns to initial state.

External memory



Fig. 5-5 Dataflow of SW performs entropy decoding in video decoder

SW entropy decoding mode (RLC mode) changes the input data format that is transferred from SW to HW. The dataflow of this mode is as Fig. 5-5. In this case the decoder software starts decoding the first picture by parsing the stream headers (1), and by performing entropy decoding. Software then writes the following items to external memory:

- Run-length-code (RLC) data (2)
- Differential motion vectors (3)
- Intra 4x4 prediction modes (4)

### Macroblock control data (5)

Last step for the software is to write the hardware control registers and to enable the hardware (6).

Hardware decodes the picture by buffering control data for several macroblocks at a time, and reading then appropriate amount of RLC data, differential motion vectors and intra modes depending on each macroblock type (7)-(10). For the rest of the decoding process (11)-(12), the functionality is identical to the HW entropy decoding mode. When the picture has been fully decoded, hardware can raise an interrupt and write the status bits in the status register.

## 5.4 Register Description

This section describes the control/status registers of the VPU\_Combo.

If HEVC is chosen to work, HEVC register base address is the base address of the HEVC. The HEVC reading MMU master register base address is hevc\_base+0x440, the writing MMU register base address is hevc\_base + 0x480, and the cache control register base address is hevc\_base + 0x400.

If H.264 decoder/encoder is chosen to work, VEPU(encoder) register base address is vpu\_base, and VDPU(decoder) base address is vpu\_base + 0x400. MMU base address is vpu\_base+0x800, and VDPU cache control base address is vpu\_base + 0xc00.

### 5.4.1 HEVC Register Summary

| <b>Name</b>                | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>                                                                                             |
|----------------------------|---------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------|
| hevc_swreg0_id             | 0x0000        | W           | 0x68761100         | ID register (read only)                                                                                        |
| hevc_swreg1_int            | 0x0004        | W           | 0x00200022         | interrupt and enable register                                                                                  |
| hevc_swreg2_sysctrl        | 0x0008        | W           | 0x00000000         | Data input and output endian setting and sys ctrl                                                              |
| hevc_swreg3_picpar         | 0x000c        | W           | 0x00000000         | picture parameters                                                                                             |
| hevc_swreg4_strm_rlc_base  | 0x0010        | W           | 0x00000000         | the stream or rlc read data base address                                                                       |
| hevc_swreg5_stream_rlc_len | 0x0014        | W           | 0x00000000         | amount of stream bytes in the input buffer or amount of rlc bytes in the input buffer                          |
| hevc_swreg6_cabactbl_base  | 0x0018        | W           | 0x00000000         | the base address of cabac table                                                                                |
| hevc_swreg7_decout_base    | 0x001c        | W           | 0x00000000         | base address of decoder output pictures suggest this register to config to even for advance ddr performance    |
| hevc_swreg8_y_virstride    | 0x0020        | W           | 0x00000000         | the output picture y fac virtual strides suggest this register to config to even for advance ddr performance   |
| hevc_swreg9_yuv_virstride  | 0x0024        | W           | 0x00000000         | the ouput picture yuv virtual stride                                                                           |
| hevc_swreg10_refer0_base   | 0x0028        | W           | 0x00000000         | base address for reference picture index 0 suggest this register to config to even for advance ddr performance |
| hevc_swreg11_refer1_base   | 0x002c        | W           | 0x00000000         | base address for reference picture index 1                                                                     |
| hevc_swreg12_refer2_base   | 0x0030        | W           | 0x00000000         | base address for reference picture index 2                                                                     |
| hevc_swreg13_refer3_base   | 0x0034        | W           | 0x00000000         | base address for reference picture index 3                                                                     |
| hevc_swreg14_refer4_base   | 0x0038        | W           | 0x00000000         | base address for reference picture index 4                                                                     |
| hevc_swreg15_refer5_base   | 0x003c        | W           | 0x00000000         | base address for reference picture index 5                                                                     |
| hevc_swreg16_refer6_base   | 0x0040        | W           | 0x00000000         | base address for reference picture index 6                                                                     |
| hevc_swreg17_refer7_base   | 0x0044        | W           | 0x00000000         | base address for reference picture index 7                                                                     |
| hevc_swreg18_refer8_base   | 0x0048        | W           | 0x00000000         | base address for reference picture index 8                                                                     |
| hevc_swreg19_refer9_base   | 0x004c        | W           | 0x00000000         | base address for reference picture index 9                                                                     |

|                                   |        |   |            |                                                                                                                 |
|-----------------------------------|--------|---|------------|-----------------------------------------------------------------------------------------------------------------|
| <u>hevc_swreg20_refer10_base</u>  | 0x0050 | W | 0x00000000 | base address for reference picture index 10                                                                     |
| <u>hevc_swreg21_refer11_base</u>  | 0x0054 | W | 0x00000000 | base address for reference picture index 11                                                                     |
| <u>hevc_swreg22_refer12_base</u>  | 0x0058 | W | 0x00000000 | base address for reference picture index 12                                                                     |
| <u>hevc_swreg23_refer13_base</u>  | 0x005c | W | 0x00000000 | base address for reference picture index 13                                                                     |
| <u>hevc_swreg24_refer14_base</u>  | 0x0060 | W | 0x00000000 | base address for reference picture index 14                                                                     |
| <u>hevc_swreg25_refer0_poc</u>    | 0x0064 | W | 0x00000000 | the poc of reference picture index 0                                                                            |
| <u>hevc_swreg26_refer1_poc</u>    | 0x0068 | W | 0x00000000 | the poc of reference picture index 1                                                                            |
| <u>hevc_swreg27_refer2_poc</u>    | 0x006c | W | 0x00000000 | the poc of reference picture index 2                                                                            |
| <u>hevc_swreg28_refer3_poc</u>    | 0x0070 | W | 0x00000000 | the poc of reference picture index 3                                                                            |
| <u>hevc_swreg29_refer4_poc</u>    | 0x0074 | W | 0x00000000 | the poc of reference picture index 4                                                                            |
| <u>hevc_swreg30_refer5_poc</u>    | 0x0078 | W | 0x00000000 | the poc of reference picture index 5                                                                            |
| <u>hevc_swreg31_refer6_poc</u>    | 0x007c | W | 0x00000000 | the poc of reference picture index 6                                                                            |
| <u>hevc_swreg32_refer7_poc</u>    | 0x0080 | W | 0x00000000 | the poc of reference picture index 7                                                                            |
| <u>hevc_swreg33_refer8_poc</u>    | 0x0084 | W | 0x00000000 | the poc of reference picture index 8                                                                            |
| <u>hevc_swreg34_refer9_poc</u>    | 0x0088 | W | 0x00000000 | the poc of reference picture index 9                                                                            |
| <u>hevc_swreg35_refer10_poc</u>   | 0x008c | W | 0x00000000 | the poc of reference picture index 10                                                                           |
| <u>hevc_swreg36_refer11_poc</u>   | 0x0090 | W | 0x00000000 | the poc of reference picture index 11                                                                           |
| <u>hevc_swreg37_refer12_poc</u>   | 0x0094 | W | 0x00000000 | the poc of reference picture index 12                                                                           |
| <u>hevc_swreg38_refer13_poc</u>   | 0x0098 | W | 0x00000000 | the poc of reference picture index 13                                                                           |
| <u>hevc_swreg39_refer14_poc</u>   | 0x009c | W | 0x00000000 | the poc of reference picture index 14                                                                           |
| <u>hevc_swreg40_cur_poc</u>       | 0x00a0 | W | 0x00000000 | the poc of cur picture                                                                                          |
| <u>hevc_swreg41_rlcwrite_base</u> | 0x00a4 | W | 0x00000000 | the base address of rlcwrite base addresswhen frame is ready , it is the address of the end of rlcwrite address |

|                                         |        |   |            |                                                                                |
|-----------------------------------------|--------|---|------------|--------------------------------------------------------------------------------|
| <u>hevc_swreg42_pps_base</u>            | 0x00a8 | W | 0x00000000 | the base address of pps                                                        |
| <u>hevc_swreg43_rps_base</u>            | 0x00ac | W | 0x00000000 | the base address of rps                                                        |
| <u>hevc_swreg44_cabac_err_or_en</u>     | 0x00b0 | W | 0x00000000 | cabac error enable config                                                      |
| <u>hevc_swreg45_cabac_err_or_status</u> | 0x00b4 | W | 0x00000000 | cabac error status                                                             |
| <u>hevc_swreg46_cabac_err_or_ctu</u>    | 0x00b8 | W | 0x00400000 | cabac error ctu                                                                |
| <u>hevc_swreg47_sao_ctu_position</u>    | 0x00bc | W | 0x00000000 | when there is any error, it is for the position of sao decode output to busifd |
| <u>hevc_swreg64_performnace_cycle</u>   | 0x0100 | W | 0x00000000 | hevc performnace cycle                                                         |
| <u>hevc_swreg65_axi_ddr_rdata</u>       | 0x0104 | W | 0x00000000 | axi ddr read data num                                                          |
| <u>hevc_swreg66_axi_ddr_wdata</u>       | 0x0108 | W | 0x00000000 | axi ddr write data num                                                         |

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

#### 5.4.2 HEVC Detail Register Description

##### hevc\_swreg0\_id

Address: Operational Base + offset (0x0000)

| Bit   | Attr | Reset Value | Description                                         |
|-------|------|-------------|-----------------------------------------------------|
| 31:16 | RO   | 0x6876      | prod_num<br>The ascii code of "hv", which is 0x6876 |
| 15    | RO   | 0x0         | reserved                                            |
| 14    | RW   | 0x0         | codec_flag<br>0: only dec<br>1: dec + enc           |
| 13    | RO   | 0x0         | reserved                                            |
| 12    | RW   | 0x1         | profile<br>0: Main<br>1: Main10                     |
| 11:9  | RO   | 0x0         | reserved                                            |
| 8     | RO   | 0x1         | level<br>0: FHD<br>1: UHD                           |
| 7:0   | RO   | 0x00        | minor_ver<br>minor version                          |

##### hevc\_swreg1\_int

Address: Operational Base + offset (0x0004)

| Bit | Attr | Reset Value | Description                                  |
|-----|------|-------------|----------------------------------------------|
| 31  | RW   | 0x0         | sw_auto_reset_en<br>0: not allow<br>1: allow |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 30:23      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                          |
| 22         | RW          | 0x0                | sw_softreset_rdy<br>when it is 1'b1, it says that softreset has been done                                                                                                                                                                                         |
| 21         | RW          | 0x1                | sw_force_softreset_valid<br>when sw_force_softreset_valid is 1'b1, sw_softrst_en will always be valid to the system no matter that whether the axi bus is idle; when sw_force_softreset_valid is 1'b0, sw_softrst_en will only be valid when the axi bus is idle. |
| 20         | RW          | 0x0                | sw_softrst_en_p<br>softreset enable signal<br>write 1 to soft reset, write 0 invalid puls register                                                                                                                                                                |
| 19         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                          |
| 18         | RW          | 0x0                | sw_cabu_end_sta<br>cabac decode end status                                                                                                                                                                                                                        |
| 17         | RW          | 0x0                | sw_colmv_ref_error_sta<br>colmv ref error status<br>when it is 1'b1, it means that inter module read the invalid dpb frame                                                                                                                                        |
| 16         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                          |
| 15         | RW          | 0x0                | sw_dec_timeout_sta<br>When high the decoder has been idling for too long. it will self reset the hardware<br>only when sw_dec_timeout_e is 1'b1, this bit is valid                                                                                                |
| 14         | RW          | 0x0                | sw_dec_error_sta<br>when high, an error is found in input data stream decoding. It will self reset the hardware                                                                                                                                                   |
| 13         | RW          | 0x0                | sw_dec_bus_sta<br>When this bit is high, there is error on the axi bus, it will self reset hardware                                                                                                                                                               |
| 12         | RW          | 0x0                | sw_dec_rdy_sta<br>when this bit is high, decoder has decoded a picture                                                                                                                                                                                            |
| 11:10      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                          |
| 9          | RW          | 0x0                | sw_dec_irq_raw<br>the raw status of sw_dec_irq,SW should reset this bit after interrupt is handled                                                                                                                                                                |
| 8          | RO          | 0x0                | sw_dec_irq<br>when high, decoder requests an interrupt.<br>$sw\_dec\_irq = sw\_dec\_irq\_raw \&& (sw\_dec\_irq\_dis == 1'b0)$                                                                                                                                     |
| 7          | RW          | 0x0                | sw_stmerror_waitdecfifo_empty<br>when it is 1'b0, the stream error process will no wait the ca2decfifo empty<br>when it is 1'b1, the stream error process will wait the ca2decfifo empty                                                                          |
| 6          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                        |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5          | RW          | 0x1                | sw_dec_timeout_e<br>If enabled HW may return timeout interrupt in case HW gets stucked while decoding picture.                                                                                            |
| 4          | RW          | 0x0                | sw_dec_irq_dis<br>When hight, there are no interrupts concerning decoder from HW.<br>Polling must be used to see the interrupt status                                                                     |
| 3:2        | RO          | 0x0                | reserved                                                                                                                                                                                                  |
| 1          | RW          | 0x1                | sw_dec_clkgate_e<br>0 = clock is running for all structures<br>1 = clock is gated for decoder structures that are not used                                                                                |
| 0          | RW          | 0x0                | sw_dec_e<br>Decoder enable. Setting this bit high will start the decoding operation. HW will reset this when picture is processed or stream error is detected or bus error or time out interrupt is given |

**hevc\_swreg2\_sysctrl**

Address: Operational Base + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:19      | RO          | 0x0                | reserved                                                                                                                                                                                                           |
| 18:12      | RW          | 0x00               | sw_strm_start_bit<br>exact bit of streamd start word where decoding can be started (asosiates with sw_str_rlc_base)                                                                                                |
| 11         | RW          | 0x0                | sw_rlc_mode<br>0 = HW decodes video from bit stream<br>1 = HW decodes video from RLC input data                                                                                                                    |
| 10         | RW          | 0x0                | sw_rlc_mode_direct_write<br>cabac decode output direct write enable<br>when this bit is enable , all the module other than cabac and busifd are not work                                                           |
| 9          | RO          | 0x0                | reserved                                                                                                                                                                                                           |
| 8          | RW          | 0x0                | sw_out_cbcr_swap<br>1'b0: cb(u) is in the lower address, cr(v) is in the higher address<br>1'b1: cb(u) is in the higher address,cr(v) is in the lower address<br>sw_in_cbcr_swap is the same with sw_out_cbcr_swap |
| 7          | RW          | 0x0                | sw_out_swap32_e<br>may be used for 64 or 128 bit environment<br>0 = no swapping of 32 bit words<br>1 = 32 bit data words are swapped                                                                               |
| 6          | RW          | 0x0                | sw_out_endian<br>0 = little endian<br>1 = big endian<br>for litter enadian , a data 0x12345678, 0x78 is stored in lower address, 0x12 is stored in higher address                                                  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5          | RW          | 0x0                | sw_str_swap64_e<br>may be used for 128 bit environment<br>0 = no swapping of 64 bit words<br>1 = 64 bit data words are swapped                                    |
| 4          | RW          | 0x0                | sw_str_swap32_e<br>may be used for 64 or 128 bit environment<br>0 = no swapping of 32 bit words<br>1 = 32 bit data words are swapped                              |
| 3          | RW          | 0x0                | sw_str_endian<br>0 = little endian<br>1 = big endian<br>for litter enadian , a data 0x12345678, 0x78 is stored in lower address, 0x12 is stored in higher address |
| 2          | RW          | 0x0                | sw_in_swap64_e<br>may be used for 128 bit environment<br>0 = no swapping of 64 bit words<br>1 = 64 bit data words are swapped                                     |
| 1          | RW          | 0x0                | sw_in_swap32_e<br>may be used for 64 or 128 bit environment<br>0 = no swapping of 32 bit words<br>1 = 32 bit data words are swapped                               |
| 0          | RW          | 0x0                | sw_in_endian<br>0 = little endian<br>1 = big endian<br>for litter enadian , a data 0x12345678, 0x78 is stored in lower address, 0x12 is stored in higher address  |

**hevc\_swreg3\_picpar**

Address: Operational Base + offset (0x000c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                          |
| 30:21      | RW          | 0x000              | sw_slice_num<br>slice number in a frame (0~199, when it is 0, it real means 1 slice in a frame)<br>just only used for rps read.<br>2013.11.27 change the meaning from count from 1, so it will be in 1~200<br>2013.11.30 sw_slice_num max value is change to 600, so sw_slice_num expand to 10bit |
| 20:12      | RW          | 0x000              | sw_uv_hor_virstride<br>picture horizontal virtual stride (the unit is 128bit)<br>the max is (4096x1.5 + 128) /16 = 0x188<br>suggest this register to config to even for advance ddr performance                                                                                                   |
| 11:9       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                       |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8:0        | RW          | 0x000              | sw_y_hor_virstride<br>picture horizontal virtual stride (the unit is 128bit)<br>the max is $(4096 \times 1.5 + 128) / 16 = 0x188$<br>suggest this register to config to even for advance ddr performance |

**hevc\_swreg4 strm rlc base**

Address: Operational Base + offset (0x0010)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4       | RW          | 0x00000000         | sw_strm_rlc_base<br>when swreg2.sw_rlc_mode =1, it is base address for rlc data<br>when swreg2.sw_rlc_mode =0, it is base address for stream ,<br>after a frame is decoded ready or error (stream error , time out ,<br>bus error) , it is the last address of the stream<br>the address should 128bit align |
| 3:0        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                     |

**hevc\_swreg5 stream rlc len**

Address: Operational Base + offset (0x0014)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:27      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                 |
| 26:0       | RW          | 0x00000000         | sw_stream_len<br>amount of stream 8bits in the input buffer<br>the max of sw_stream_len : $4096 \times 2304 \times 1.5 \times 1.5 = 0x1440000$<br>128bits unit: $0x1440000 / 16 = 0x144000$<br>it is count from 0<br>2013.10.15 change to 23bit for zty's suggestion<br>2013.10.28, amount of stream data bytes in input buffer.<br>it is count from 1, change to 27bits |

**hevc\_swreg6 cabactbl base**

Address: Operational Base + offset (0x0018)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------|
| 31:4       | RW          | 0x00000000         | sw_cabactbl_base<br>the base address of cabac table<br>the address should 128bit align |
| 3:0        | RO          | 0x0                | reserved                                                                               |

**hevc\_swreg7 decout base**

Address: Operational Base + offset (0x001c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                             |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------|
| 31:4       | RW          | 0x00000000         | sw_decout_base<br>base address of decoder output picture<br>the address should be 128bit align |
| 3:0        | RO          | 0x0                | reserved                                                                                       |

**hevc\_swreg8\_y\_virstride**

Address: Operational Base + offset (0x0020)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20      | RO          | 0x0                | reserved                                                                                                                                                                                             |
| 19:0       | RW          | 0x000000           | sw_y_virstride<br>the output picture y virtual stride (the unit is 128bit)<br>the max: (4096x1.5 +128) x 2304 = 0xdc8000<br>we can know the sw_uvout_base = sw_decout_base +<br>(sw_y_virstride <<4) |

**hevc\_swreg9\_yuv\_virstride**

Address: Operational Base + offset (0x0024)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:21      | RO          | 0x0                | reserved                                                                                                                                                                                                          |
| 20:0       | RW          | 0x0000000          | sw_yuv_virstride<br>the output picture yuv virtual stride (the unit is 128bit)<br>the max : (4096x1.5 +128) x 2304 x1.5 = 0x14ac000<br>we can know the sw_mvout_base = sw_decout_base +<br>(sw_yuv_virstride <<4) |

**hevc\_swreg10\_refer0\_base**

Address: Operational Base + offset (0x0028)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------|
| 31:4       | RW          | 0x00000000         | sw_refer0_base<br>base address for reference picture index 0 (the address should be 128bit align) |
| 3:0        | RW          | 0x0                | sw_ref_valid_0_3<br>valid flag for picture index 0 ~3                                             |

**hevc\_swreg11\_refer1\_base**

Address: Operational Base + offset (0x002c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------|
| 31:4       | RW          | 0x00000000         | sw_refer1_base<br>base address for reference picture index 1 (the address should be 128bit align) |
| 3:0        | RW          | 0x0                | sw_ref_valid_4_7<br>valid flag for picture index 4 ~7                                             |

**hevc\_swreg12\_refer2\_base**

Address: Operational Base + offset (0x0030)

| Bit  | Attr | Reset Value | Description                                                                                       |
|------|------|-------------|---------------------------------------------------------------------------------------------------|
| 31:4 | RW   | 0x00000000  | sw_refer2_base<br>base address for reference picture index 2 (the address should be 128bit align) |
| 3:0  | RW   | 0x0         | sw_ref_valid_8_11<br>valid flag for picture index 8~11                                            |

**hevc\_swreg13\_refer3\_base**

Address: Operational Base + offset (0x0034)

| Bit  | Attr | Reset Value | Description                                                                                       |
|------|------|-------------|---------------------------------------------------------------------------------------------------|
| 31:4 | RW   | 0x00000000  | sw_refer3_base<br>base address for reference picture index 3 (the address should be 128bit align) |
| 3    | RO   | 0x0         | reserved                                                                                          |
| 2:0  | RW   | 0x0         | sw_ref_valid_12_14<br>valid flag for picture index 12~14                                          |

**hevc\_swreg14\_refer4\_base**

Address: Operational Base + offset (0x0038)

| Bit  | Attr | Reset Value | Description                                                                                      |
|------|------|-------------|--------------------------------------------------------------------------------------------------|
| 31:4 | RW   | 0x00000000  | sw_refer4_base<br>base address for reference picture index 4(the address should be 128bit align) |
| 3:0  | RO   | 0x0         | reserved                                                                                         |

**hevc\_swreg15\_refer5\_base**

Address: Operational Base + offset (0x003c)

| Bit  | Attr | Reset Value | Description                                                                                      |
|------|------|-------------|--------------------------------------------------------------------------------------------------|
| 31:4 | RW   | 0x00000000  | sw_refer5_base<br>base address for reference picture index 5(the address should be 128bit align) |
| 3:0  | RO   | 0x0         | reserved                                                                                         |

**hevc\_swreg16\_refer6\_base**

Address: Operational Base + offset (0x0040)

| Bit  | Attr | Reset Value | Description                                                                                      |
|------|------|-------------|--------------------------------------------------------------------------------------------------|
| 31:4 | RW   | 0x00000000  | sw_refer6_base<br>base address for reference picture index 6(the address should be 128bit align) |
| 3:0  | RO   | 0x0         | reserved                                                                                         |

**hevc\_swreg17\_refer7\_base**

Address: Operational Base + offset (0x0044)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                               |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------|
| 31:4       | RW          | 0x00000000         | sw_refer7_base<br>base address for reference picture index 7(the address should be 128bit align) |
| 3:0        | RO          | 0x0                | reserved                                                                                         |

**hevc\_swreg18\_refer8\_base**

Address: Operational Base + offset (0x0048)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                               |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------|
| 31:4       | RW          | 0x00000000         | sw_refer8_base<br>base address for reference picture index 8(the address should be 128bit align) |
| 3:0        | RO          | 0x0                | reserved                                                                                         |

**hevc\_swreg19\_refer9\_base**

Address: Operational Base + offset (0x004c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                               |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------|
| 31:4       | RW          | 0x00000000         | sw_refer9_base<br>base address for reference picture index 9(the address should be 128bit align) |
| 3:0        | RO          | 0x0                | reserved                                                                                         |

**hevc\_swreg20\_refer10\_base**

Address: Operational Base + offset (0x0050)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------|
| 31:4       | RW          | 0x00000000         | sw_refer10_base<br>base address for reference picture index 10(the address should be 128bit align) |
| 3:0        | RO          | 0x0                | reserved                                                                                           |

**hevc\_swreg21\_refer11\_base**

Address: Operational Base + offset (0x0054)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------|
| 31:4       | RW          | 0x00000000         | sw_refer11_base<br>base address for reference picture index 11(the address should be 128bit align) |
| 3:0        | RO          | 0x0                | reserved                                                                                           |

**hevc\_swreg22\_refer12\_base**

Address: Operational Base + offset (0x0058)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------|
| 31:4       | RW          | 0x00000000         | sw_refer12_base<br>base address for reference picture index 12(the address should be 128bit align) |

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

**hevc\_swreg23\_refer13\_base**

Address: Operational Base + offset (0x005c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------|
| 31:4       | RW          | 0x00000000         | sw_refer13_base<br>base address for reference picture index 13(the address should be 128bit align) |
| 3:0        | RO          | 0x0                | reserved                                                                                           |

**hevc\_swreg24\_refer14\_base**

Address: Operational Base + offset (0x0060)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------|
| 31:4       | RW          | 0x00000000         | sw_refer14_base<br>base address for reference picture index 14(the address should be 128bit align) |
| 3:0        | RO          | 0x0                | reserved                                                                                           |

**hevc\_swreg25\_refer0\_poc**

Address: Operational Base + offset (0x0064)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                    |
|------------|-------------|--------------------|-------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_refer0_poc<br>the poc of reference picture index 0 |

**hevc\_swreg26\_refer1\_poc**

Address: Operational Base + offset (0x0068)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                    |
|------------|-------------|--------------------|-------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_refer1_poc<br>the poc of reference picture index 1 |

**hevc\_swreg27\_refer2\_poc**

Address: Operational Base + offset (0x006c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                    |
|------------|-------------|--------------------|-------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_refer2_poc<br>the poc of reference picture index 2 |

**hevc\_swreg28\_refer3\_poc**

Address: Operational Base + offset (0x0070)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                    |
|------------|-------------|--------------------|-------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_refer3_poc<br>the poc of reference picture index 3 |

**hevc\_swreg29\_refer4\_poc**

Address: Operational Base + offset (0x0074)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                    |
|------------|-------------|--------------------|-------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_refer4_poc<br>the poc of reference picture index 4 |

**hevc\_swreg30\_refer5\_poc**

Address: Operational Base + offset (0x0078)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                    |
|------------|-------------|--------------------|-------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_refer5_poc<br>the poc of reference picture index 5 |

**hevc\_swreg31\_refer6\_poc**

Address: Operational Base + offset (0x007c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                    |
|------------|-------------|--------------------|-------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_refer6_poc<br>the poc of reference picture index 6 |

**hevc\_swreg32\_refer7\_poc**

Address: Operational Base + offset (0x0080)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                    |
|------------|-------------|--------------------|-------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_refer7_poc<br>the poc of reference picture index 7 |

**hevc\_swreg33\_refer8\_poc**

Address: Operational Base + offset (0x0084)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                    |
|------------|-------------|--------------------|-------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_refer8_poc<br>the poc of reference picture index 8 |

**hevc\_swreg34\_refer9\_poc**

Address: Operational Base + offset (0x0088)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                    |
|------------|-------------|--------------------|-------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_refer9_poc<br>the poc of reference picture index 9 |

**hevc\_swreg35\_refer10\_poc**

Address: Operational Base + offset (0x008c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                      |
|------------|-------------|--------------------|---------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_refer10_poc<br>the poc of reference picture index 10 |

**hevc\_swreg36\_refer11\_poc**

Address: Operational Base + offset (0x0090)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                      |
|------------|-------------|--------------------|---------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_refer11_poc<br>the poc of reference picture index 11 |

**hevc\_swreg37\_refer12\_poc**

Address: Operational Base + offset (0x0094)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                      |
|------------|-------------|--------------------|---------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_refer12_poc<br>the poc of reference picture index 12 |

**hevc\_swreg38\_refer13\_poc**

Address: Operational Base + offset (0x0098)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                      |
|------------|-------------|--------------------|---------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_refer13_poc<br>the poc of reference picture index 13 |

**hevc\_swreg39\_refer14\_poc**

Address: Operational Base + offset (0x009c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                      |
|------------|-------------|--------------------|---------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_refer14_poc<br>the poc of reference picture index 14 |

**hevc\_swreg40\_cur\_poc**

Address: Operational Base + offset (0x00a0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                       |
|------------|-------------|--------------------|------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_cur_poc<br>the poc of the cur picture |

**hevc\_swreg41\_rlcwrite\_base**

Address: Operational Base + offset (0x00a4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                               |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3       | RW          | 0x00000000         | sw_rlcwrite_base<br>the base address of rlcwrite(the address should 64bit align)<br>cabac output write to this rlcwrite base address when<br>sw_rlc_mode_direct_write in swreg2_sysctrl is valid |
| 2:0        | RO          | 0x0                | reserved                                                                                                                                                                                         |

**hevc\_swreg42\_pps\_base**

Address: Operational Base + offset (0x00a8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4       | RW          | 0x00000000         | sw_pps_base<br>the base address of pps ( the address should 128bit align )<br>it is for storing sps(sequence parameter set) and pps(picture parameter set) |
| 3:0        | RO          | 0x0                | reserved                                                                                                                                                   |

**hevc\_swreg43\_rps\_base**

Address: Operational Base + offset (0x00ac)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------|
| 31:4       | RW          | 0x00000000         | sw_rps_base<br>rps(reference picture set) base address (the address should 128bit align) |
| 3:0        | RO          | 0x0                | reserved                                                                                 |

**hevc\_swreg44\_cabac\_error\_en**

Address: Operational Base + offset (0x00b0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                          |
|------------|-------------|--------------------|---------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                    |
| 27:0       | RW          | 0x00000000         | sw_cabac_error_e<br>cabac error enable regs |

**hevc\_swreg45\_cabac\_error\_status**

Address: Operational Base + offset (0x00b4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                    |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28      | RW          | 0x0                | sw_colmv_error_ref_picidx<br>when sw_colmv_ref_error_sta is 1'b1, these bits are used for tell which dpb frame is invalid but is read by inter module |
| 27:0       | RW          | 0x00000000         | sw_cabac_error_status<br>cabac error status                                                                                                           |

**hevc\_swreg46\_cabac\_error\_ctu**

Address: Operational Base + offset (0x00b8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------|
| 31:23      | RO          | 0x0                | reserved                                                                               |
| 22:16      | RW          | 0x40               | sw_streamfifo_space2full<br>It is for debug use, to tell the stream fifo space to full |
| 15:8       | RW          | 0x00               | sw_cabac_error_ctu_yoffset<br>cabac error ctu yoffset                                  |
| 7:0        | RW          | 0x00               | sw_cabac_error_ctu_xoffset<br>cabac error ctu xoffset                                  |

**hevc\_swreg47\_sao\_ctu\_position**

Address: Operational Base + offset (0x00bc)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                             |
|------------|-------------|--------------------|----------------------------------------------------------------|
| 31:26      | RO          | 0x0                | reserved                                                       |
| 25:16      | RW          | 0x000              | sw_saowr_yoffset<br>saowr y offset , its unit is 4 pixels      |
| 15:9       | RO          | 0x0                | reserved                                                       |
| 8:0        | RW          | 0x000              | sw_saowr_xoffset<br>saowr x address offset, its unit is 128bit |

**hevc\_swreg64\_performance\_cycle**

Address: Operational Base + offset (0x0100)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                             |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_performance_cycle<br>hevc running cycle<br>if just want to analys a frame performance cycle, should set the register 0 before start a frame |

**hevc\_swreg65\_axi\_ddr\_rdata**

Address: Operational Base + offset (0x0104)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                      |
|------------|-------------|--------------------|---------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_axi_ddr_rdata<br>axi ddr rdata num, the unit is byte |

**hevc\_swreg66\_axi\_ddr\_wdata**

Address: Operational Base + offset (0x0108)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                           |
|------------|-------------|--------------------|----------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_axi_ddr_wdata<br>hevc write data byte num |

**5.4.3 HEVC MMU Register Summary**

| Name                       | Offset | Size | Reset Value | Description                                                                                                               |
|----------------------------|--------|------|-------------|---------------------------------------------------------------------------------------------------------------------------|
| rkvdec mmu DTE ADDR        | 0x0000 | W    | 0x00000000  | MMU current page Table addressIt is only can be written when MMU state is disable or page fault or mmu enable stall state |
| rkvdec mmu STATUS          | 0x0004 | W    | 0x00000018  | MMU status register                                                                                                       |
| rkvdec mmu COMMAND         | 0x0008 | W    | 0x00000000  | MMU command register                                                                                                      |
| rkvdec mmu PAGE FAULT ADDR | 0x000c | W    | 0x00000000  | MMU logical address of last page fault                                                                                    |
| rkvdec mmu ZAP ONE LINE    | 0x0010 | W    | 0x00000000  | MMU Zap cache line register                                                                                               |
| rkvdec mmu INT RAWSTATUS   | 0x0014 | W    | 0x00000000  | MMU raw interrupt status register                                                                                         |
| rkvdec mmu INT CLEAR       | 0x0018 | W    | 0x00000000  | MMU raw interrupt status register                                                                                         |
| rkvdec mmu INT MASK        | 0x001c | W    | 0x00000000  | MMU raw interrupt status register                                                                                         |
| rkvdec mmu INT STATUS      | 0x0020 | W    | 0x00000000  | MMU raw interrupt status register                                                                                         |
| rkvdec mmu AUTO GATING     | 0x0024 | W    | 0x00000001  | mmu auto gating                                                                                                           |

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

#### 5.4.4 HEVC MMU Detail Register Description

##### rkvdec mmu DTE ADDR

Address: Operational Base + offset (0x0000)

| Bit  | Attr | Reset Value | Description                                                         |
|------|------|-------------|---------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | MMU_DTE_ADDR<br>mmu dte base addr , the address must be 4kb aligned |

##### rkvdec mmu STATUS

Address: Operational Base + offset (0x0004)

| Bit   | Attr | Reset Value | Description                                                                                                     |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------|
| 31:11 | RO   | 0x0         | reserved                                                                                                        |
| 10:6  | RO   | 0x00        | PAGE_FAULT_BUS_ID<br>Index of master responsible for last page fault                                            |
| 5     | RO   | 0x0         | PAGE_FAULT_IS_WRITE<br>The direction of access for last page fault:<br>0 = Read<br>1 = Write                    |
| 4     | RO   | 0x1         | REPLAY_BUFFER_EMPTY<br>The MMU replay buffer is empty                                                           |
| 3     | RO   | 0x1         | MMU_IDLE<br>The MMU is idle when accesses are being translated and there are no unfinished translated accesses. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------|
| 2          | RO          | 0x0                | STAIL_ACTIVE<br>MMU stall mode currently enabled. The mode is enabled by command             |
| 1          | RO          | 0x0                | PAGE_FAULT_ACTIVE<br>MMU page fault mode currently enabled . The mode is enabled by command. |
| 0          | RO          | 0x0                | PAGING_ENABLED<br>Paging is enabled                                                          |

**rkvdec\_mmummu\_COMMAND**

Address: Operational Base + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3       | RO          | 0x0                | reserved                                                                                                                                                                                             |
| 2:0        | WO          | 0x0                | MMU_CMD<br>MMU_CMD. This can be:<br>0: MMU_ENABLE_PAGING<br>1: MMU_DISABLE_PAGING<br>2: MMU_ENABLE_STALL<br>3: MMU_DISABLE_STALL<br>4: MMU_ZAP_CACHE<br>5: MMU_PAGE_FAULT_DONE<br>6: MMU_FORCE_RESET |

**rkvdec\_mmummu\_PAGE\_FAULT\_ADDR**

Address: Operational Base + offset (0x000c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                            |
|------------|-------------|--------------------|-----------------------------------------------|
| 31:0       | RO          | 0x00000000         | PAGE_FAULT_ADDR<br>address of last page fault |

**rkvdec\_mmummu\_ZAP\_ONE\_LINE**

Address: Operational Base + offset (0x0010)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------|
| 31:0       | WO          | 0x00000000         | MMU_ZAP_ONE_LINE<br>address to be invalidated from the page table cache |

**rkvdec\_mmummu\_INT\_RAWSTAT**

Address: Operational Base + offset (0x0014)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>               |
|------------|-------------|--------------------|----------------------------------|
| 31:2       | RO          | 0x0                | reserved                         |
| 1          | RW          | 0x0                | READ_BUS_ERROR<br>read bus error |
| 0          | RW          | 0x0                | PAGE_FAULT<br>page fault         |

**rkvdec mmu INT CLEAR**

Address: Operational Base + offset (0x0018)

| Bit  | Attr | Reset Value | Description                      |
|------|------|-------------|----------------------------------|
| 31:2 | RO   | 0x0         | reserved                         |
| 1    | WO   | 0x0         | READ_BUS_ERROR<br>read bus error |
| 0    | WO   | 0x0         | PAGE_FAULT<br>page fault         |

**rkvdec mmu INT MASK**

Address: Operational Base + offset (0x001c)

| Bit  | Attr | Reset Value | Description                                                                                              |
|------|------|-------------|----------------------------------------------------------------------------------------------------------|
| 31:2 | RO   | 0x0         | reserved                                                                                                 |
| 1    | RW   | 0x0         | READ_BUS_ERROR<br>read bus error<br>enable an interrupt source if the corresponding mask bit is set to 1 |
| 0    | RW   | 0x0         | PAGE_FAULT<br>page fault<br>enable an interrupt source if the corresponding mask bit is set to 1         |

**rkvdec mmu INT STATUS**

Address: Operational Base + offset (0x0020)

| Bit  | Attr | Reset Value | Description                      |
|------|------|-------------|----------------------------------|
| 31:2 | RO   | 0x0         | reserved                         |
| 1    | RO   | 0x0         | READ_BUS_ERROR<br>read bus error |
| 0    | RO   | 0x0         | PAGE_FAULT<br>page fault         |

**rkvdec mmu AUTO GATING**

Address: Operational Base + offset (0x0024)

| Bit  | Attr | Reset Value | Description                                                          |
|------|------|-------------|----------------------------------------------------------------------|
| 31:1 | RO   | 0x0         | reserved                                                             |
| 0    | RW   | 0x1         | mmu_auto_gating<br>when it is 1'b1, the mmu will auto gating it self |

**5.4.5 HEVC CACHE Register Summary**

| Name               | Offset | Size | Reset Value | Description      |
|--------------------|--------|------|-------------|------------------|
| pref_cache VERSION | 0x0000 | W    | 0xcac20101  | VERSION register |
| pref_cache SIZE    | 0x0004 | W    | 0x07100206  | L2 cache SIZE    |

| Name                     | Offset | Size | Reset Value | Description                                                                                                                                                                                                                                                                                                                                            |
|--------------------------|--------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| pref_cache_STATUS        | 0x0008 | W    | 0x00000000  | Status register                                                                                                                                                                                                                                                                                                                                        |
| pref_cache_COMMAND       | 0x0010 | W    | 0x00000000  | Command setting register                                                                                                                                                                                                                                                                                                                               |
| pref_cache_CLEAR_PAGE    | 0x0014 | W    | 0x00000000  | clear page register                                                                                                                                                                                                                                                                                                                                    |
| pref_cache_MAX_READS     | 0x0018 | W    | 0x0000001c  | maximum read register                                                                                                                                                                                                                                                                                                                                  |
| pref_cache_ENABLE        | 0x001c | W    | 0x00000003  | enables cacheable accesses and cache read allocation                                                                                                                                                                                                                                                                                                   |
| pref_cache_PERFCNT_SR_C0 | 0x0020 | W    | 0x00000000  | performance counter 0 source register                                                                                                                                                                                                                                                                                                                  |
| pref_cache_PERFCNT_VAL_0 | 0x0024 | W    | 0x00000000  | performance counter 0 value register                                                                                                                                                                                                                                                                                                                   |
| pref_cache_PERFCNT_SR_C1 | 0x0028 | W    | 0x00000000  | This register holds all the possible source values for Performance Counter 00: total clock cycles1: active clock cycles2: read transactions, master3: word reads, master4: read transactions, slave5: word reads, slave6: read hit, slave7: read misses, slave8: read invalidates, slave9: cacheable read transactions, slave10: bad hit number, slave |
| pref_cache_PERFCNT_VAL_1 | 0x002c | W    | 0x00000000  | performance counter 1 value register                                                                                                                                                                                                                                                                                                                   |

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

#### 5.4.6 HEVC CACHE Detail Register Description

##### pref\_cache VERSION

Address: Operational Base + offset (0x0000)

| Bit   | Attr | Reset Value | Description                            |
|-------|------|-------------|----------------------------------------|
| 31:16 | RO   | 0xcac2      | PRODUCT_ID<br>Field0000 Description    |
| 15:8  | RO   | 0x01        | VERSION_MAJOR<br>Field0000 Description |
| 7:0   | RO   | 0x01        | VERSION_MINOR<br>Field0000 Description |

##### pref\_cache SIZE

Address: Operational Base + offset (0x0004)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------|
| 31:24      | RO          | 0x07               | External_bus_width<br>Log2 external bus width in bits                                                           |
| 23:16      | RO          | 0x10               | CACHE_SIZE<br>Log2 cache size in bytes<br>for Y channel , its value is 0x10<br>for UV channel, its value is 0xf |
| 15:8       | RO          | 0x02               | ASSOCIATIVITY<br>Log2 associativity                                                                             |
| 7:0        | RO          | 0x06               | LINE_SIZE<br>Log2 line size in bytes                                                                            |

**pref cache STATUS**

Address: Operational Base + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 31:2       | RO          | 0x0                | reserved                                                 |
| 1          | RW          | 0x0                | DATA_BUSY<br>set when the cache is busy handling data    |
| 0          | RW          | 0x0                | CMD_BUSY<br>set when the cache is busy handling commands |

**pref cache COMMAND**

Address: Operational Base + offset (0x0010)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6       | RO          | 0x0                | reserved                                                                                                                                   |
| 5:4        | RW          | 0x0                | sw_addrb_sel<br>2'b00: to sel b[14:6]<br>2'b01: to sel b[15:9], b[7:6]<br>2'b10: to sel b[16:10], b[7:6]<br>2'b11: to sel b[17:11], b[7:6] |
| 3:0        | RW          | 0x0                | COMMAND<br>The possible command is<br>1 = Clear entire cache                                                                               |

**pref cache CLEAR PAGE**

Address: Operational Base + offset (0x0014)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------|
| 31:0       | WO          | 0x00000000         | CLEAR_PAGE<br>writing an address, invalidates all lines in that page from the cache |

**pref cache MAX READS**

Address: Operational Base + offset (0x0018)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------|
| 31:5       | RO          | 0x0                | reserved                                                                      |
| 4:0        | RW          | 0x1c               | MAX_READS<br>Limit the number of outstanding read transactions to this amount |

**pref cache ENABLE**

Address: Operational Base + offset (0x001c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x0                | reserved                                                                                                                                             |
| 4          | RW          | 0x0                | sw_cache_linsize<br>1'b0: the cache line is 32bytes<br>1'b1: the cache line is 64bytes                                                               |
| 3          | RW          | 0x0                | sw_cache_clk_disgate<br>cache clk disgate<br>when it is 1'b0, enable cache clk auto clk gating<br>when it is 1'b1, disable cache clk auto clk gating |
| 2          | RW          | 0x0                | sw_readbuffer_counter_reject_en<br>default is 1'b0, for enhance cacheable read performance in readbuffer.<br>1'b1: normal origin counter reject      |
| 1          | RW          | 0x1                | permit_cache_read_allocate<br>1'b1: permit cache read allocate                                                                                       |
| 0          | RW          | 0x1                | permit_cacheable_access<br>1'b1: permit cacheable access                                                                                             |

**pref cache PERFCNT\_SRC0**

Address: Operational Base + offset (0x0020)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:7       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 6:0        | RW          | 0x00               | PERFCNT_SRC0<br>This register holds all the possible source values for Performance Counter 0<br>0: disabled<br>1: total clock cycles<br>2: active clock cycles<br>3: read transactions, master<br>4: word reads, master<br>5: read transactions, slave<br>6: word reads, slave<br>7: read hit, slave<br>8: read misses, slave<br>9: read invalidates, slave<br>10: cacheable read transactions, slave<br>11: bad hit number, slave |

**pref cache PERFCNT VAL0**

Address: Operational Base + offset (0x0024)

| Bit  | Attr | Reset Value | Description                                 |
|------|------|-------------|---------------------------------------------|
| 31:0 | RW   | 0x00000000  | PERFCNT_VAL0<br>Performance counter 0 value |

**pref cache PERFCNT SRC1**

Address: Operational Base + offset (0x0028)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:7 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 6:0  | RW   | 0x00        | PERFCNT_SRC1<br>This register holds all the possible source values for Performance Counter 1<br>0: disabled<br>1: total clock cycles<br>2: active clock cycles<br>3: read transactions, master<br>4: word reads, master<br>5: read transactions, slave<br>6: word reads, slave<br>7: read hit, slave<br>8: read misses, slave<br>9: read invalidates, slave<br>10: cacheable read transactions, slave<br>11: bad hit nmber, slave |

**pref cache PERFCNT VAL1**

Address: Operational Base + offset (0x002c)

| Bit  | Attr | Reset Value | Description                                 |
|------|------|-------------|---------------------------------------------|
| 31:0 | RW   | 0x00000000  | PERFCNT_VAL1<br>Performance counter 1 value |

**5.4.7 VEPU121 Register Summary**

| Name         | Offset | Size | Reset Value | Description                           |
|--------------|--------|------|-------------|---------------------------------------|
| VEPU_swreg_0 | 0x0000 | W    | 0x00000000  | 1st quantization for jpeg lumin table |
| VEPU_swreg_1 | 0x0004 | W    | 0x00000000  | 2st quantization for jpeg lumin table |
| VEPU_swreg_2 | 0x0008 | W    | 0x00000000  | 3st quantization for jpeg lumin table |

| <b>Name</b>          | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>                                        |
|----------------------|---------------|-------------|--------------------|-----------------------------------------------------------|
| <u>VEPU_swreg_3</u>  | 0x000c        | W           | 0x00000000         | 4st quantization for jpeg lumin table                     |
| <u>VEPU_swreg_4</u>  | 0x0010        | W           | 0x00000000         | 5st quantization for jpeg lumin table                     |
| <u>VEPU_swreg_5</u>  | 0x0014        | W           | 0x00000000         | 6st quantization for jpeg lumin table/part 1 for qp round |
| <u>VEPU_swreg_6</u>  | 0x0018        | W           | 0x00000000         | 7st quantization for jpeg lumin table                     |
| <u>VEPU_swreg_7</u>  | 0x001c        | W           | 0x00000000         | 8st quantization for jpeg lumin table                     |
| <u>VEPU_swreg_8</u>  | 0x0020        | W           | 0x00000000         | 9st quantization for jpeg lumin table                     |
| <u>VEPU_swreg_9</u>  | 0x0024        | W           | 0x00000000         | 10st quantization for jpeg lumin table                    |
| <u>VEPU_swreg_10</u> | 0x0028        | W           | 0x00000000         | 11st quantization for jpeg lumin table                    |
| <u>VEPU_swreg_11</u> | 0x002c        | W           | 0x00000000         | 12st quantization for jpeg lumin table                    |
| <u>VEPU_swreg_12</u> | 0x0030        | W           | 0x00000000         | 13st quantization for jpeg lumin table                    |
| <u>VEPU_swreg_13</u> | 0x0034        | W           | 0x00000000         | 14st quantization for jpeg lumin table                    |
| <u>VEPU_swreg_14</u> | 0x0038        | W           | 0x00000000         | 15st quantization for jpeg lumin table                    |
| <u>VEPU_swreg_15</u> | 0x003c        | W           | 0x00000000         | 16st quantization for jpeg lumin table                    |
| <u>VEPU_swreg_16</u> | 0x0040        | W           | 0x00000000         | 1st quantization for jpeg chroma table                    |

| <b>Name</b>          | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>                                         |
|----------------------|---------------|-------------|--------------------|------------------------------------------------------------|
| <u>VEPU_swreg_17</u> | 0x0044        | W           | 0x00000000         | 2st quantization for jpeg chroma table                     |
| <u>VEPU_swreg_18</u> | 0x0048        | W           | 0x00000000         | 3st quantization for jpeg chroma table                     |
| <u>VEPU_swreg_19</u> | 0x004c        | W           | 0x00000000         | 4st quantization for jpeg chroma table                     |
| <u>VEPU_swreg_20</u> | 0x0050        | W           | 0x00000000         | 5st quantization for jpeg chroma table                     |
| <u>VEPU_swreg_21</u> | 0x0054        | W           | 0x00000000         | 6st quantization for jpeg chroma table                     |
| <u>VEPU_swreg_22</u> | 0x0058        | W           | 0x00000000         | 7st quantization for jpeg chroma table                     |
| <u>VEPU_swreg_23</u> | 0x005c        | W           | 0x00000000         | 8st quantization for jpeg chroma table/part 3 for qp round |
| <u>VEPU_swreg_24</u> | 0x0060        | W           | 0x00000000         | 9st quantization for jpeg chroma table                     |
| <u>VEPU_swreg_25</u> | 0x0064        | W           | 0x00000000         | 10st quantization for jpeg chroma table                    |
| <u>VEPU_swreg_26</u> | 0x0068        | W           | 0x00000000         | 11st quantization for jpeg chroma table                    |
| <u>VEPU_swreg_27</u> | 0x006c        | W           | 0x00000000         | 12st quantization for jpeg chroma                          |
| <u>VEPU_swreg_28</u> | 0x0070        | W           | 0x00000000         | 13st quantization for jpeg chroma                          |
| <u>VEPU_swreg_29</u> | 0x0074        | W           | 0x00000000         | 14st quantization for jpeg chroma                          |
| <u>VEPU_swreg_30</u> | 0x0078        | W           | 0x00000000         | 15st quantization for jpeg chroma                          |

| <b>Name</b>          | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>                       |
|----------------------|---------------|-------------|--------------------|------------------------------------------|
| <u>VEPU_swreg_31</u> | 0x007c        | W           | 0x00000000         | 16st quantization for jpeg chroma        |
| <u>VEPU_swreg_44</u> | 0x00b0        | W           | 0x00000000         | Intra slice bitmap                       |
| <u>VEPU_swreg_45</u> | 0x00b4        | W           | 0x00000000         | Intra slice bitmap1                      |
| <u>VEPU_swreg_46</u> | 0x00b8        | W           | 0x00000000         | intra macro block sellect register       |
| <u>VEPU_swreg_47</u> | 0x00bc        | W           | 0x00000000         | CIR intra control register               |
| <u>VEPU_swreg_48</u> | 0x00c0        | W           | 0x00000000         | base addr for input luma                 |
| <u>VEPU_swreg_49</u> | 0x00c4        | W           | 0x00000000         | base address for input cb                |
| <u>VEPU_swreg_50</u> | 0x00c8        | W           | 0x00000000         | input cr start address                   |
| <u>VEPU_swreg_51</u> | 0x00cc        | W           | 0x00000000         | stream header bits left register         |
| <u>VEPU_swreg_52</u> | 0x00d0        | W           | 0x00000000         | stream header bits left register         |
| <u>VEPU_swreg_53</u> | 0x00d4        | W           | 0x00000000         | stream buffer register                   |
| <u>VEPU_swreg_54</u> | 0x00d8        | W           | 0x01010000         | axi control register                     |
| <u>VEPU_swreg_55</u> | 0x00dc        | W           | 0x00000000         | qp related                               |
| <u>VEPU_swreg_56</u> | 0x00e0        | W           | 0x00000000         | the luma reference frame start address   |
| <u>VEPU_swreg_57</u> | 0x00e4        | W           | 0x00000000         | the chroma reference frame start address |
| <u>VEPU_swreg_58</u> | 0x00e8        | W           | 0x00000000         | the result of qp sum div2                |
| <u>VEPU_swreg_59</u> | 0x00ec        | W           | 0x00000000         | h264 slice ctrl                          |
| <u>VEPU_swreg_60</u> | 0x00f0        | W           | 0x00000000         | spill ctrl                               |
| <u>VEPU_swreg_61</u> | 0x00f4        | W           | 0x00000000         | input luminance information              |
| <u>VEPU_swreg_62</u> | 0x00f8        | W           | 0x00000000         | rlc_sum                                  |

| <b>Name</b>                | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>                     |
|----------------------------|---------------|-------------|--------------------|----------------------------------------|
| <u>VEPU_swreg_63</u>       | 0x00fc        | W           | 0x00000000         | the reconstructed luma start address   |
| <u>VEPU_swreg_64</u>       | 0x0100        | W           | 0x00000000         | the reconstructed chroma start address |
| <u>VEPU_swreg_65_reuse</u> | 0x0104        | W           | 0x00000000         | checkpoint 1 and 2                     |
| <u>VEPU_swreg_66_reuse</u> | 0x0108        | W           | 0x00000000         | checkpoint 3 and 4                     |
| <u>VEPU_swreg_67_reuse</u> | 0x010c        | W           | 0x00000000         | checkpoint 5 and 6                     |
| <u>VEPU_swreg_68_reuse</u> | 0x0110        | W           | 0x00000000         | checkpoint 7 and 8                     |
| <u>VEPU_swreg_69_reuse</u> | 0x0114        | W           | 0x00000000         | checkpoint 9 and 10                    |
| <u>VEPU_swreg_70_reuse</u> | 0x0118        | W           | 0x00000000         | checkpoint word error 1 and 2          |
| <u>VEPU_swreg_71_reuse</u> | 0x011c        | W           | 0x00000000         | checkpoint word error 1 and 2          |
| <u>VEPU_swreg_72_reuse</u> | 0x0120        | W           | 0x00000000         | checkpoint word error 1 and 2          |
| <u>VEPU_swreg_73_reuse</u> | 0x0124        | W           | 0x00000000         | checkpoint delta QP register           |
| <u>VEPU_swreg_74</u>       | 0x0128        | W           | 0x00000000         | input image format                     |
| <u>VEPU_swreg_75</u>       | 0x012c        | W           | 0x00000000         | intra/inter mode                       |
| <u>VEPU_swreg_76_reuse</u> | 0x0130        | W           | 0x00000000         | encoder control register 0             |
| <u>VEPU_swreg_77</u>       | 0x0134        | W           | 0x00000000         | output stream start address            |
| <u>VEPU_swreg_78</u>       | 0x0138        | W           | 0x00000000         | output control start address           |
| <u>VEPU_swreg_79</u>       | 0x013c        | W           | 0x00000000         | next picture luminance start address   |
| <u>VEPU_swreg_80</u>       | 0x0140        | W           | 0x00000000         | Base address for MV output             |
| <u>VEPU_swreg_81</u>       | 0x0144        | W           | 0x00000000         | the cabac table start address          |
| <u>VEPU_swreg_82</u>       | 0x0148        | W           | 0x00000000         | ROI area register                      |

| <b>Name</b>                 | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>                         |
|-----------------------------|---------------|-------------|--------------------|--------------------------------------------|
| <u>VEPU_swreg_83</u>        | 0x014c        | W           | 0x00000000         | the second of ROI area register            |
| <u>VEPU_swreg_84</u>        | 0x0150        | W           | 0x00000000         | Stabilization matrix1                      |
| <u>VEPU_swreg_85</u>        | 0x0154        | W           | 0x00000000         | Stabilization matrix2                      |
| <u>VEPU_swreg_86</u>        | 0x0158        | W           | 0x00000000         | Stabilization matrix3                      |
| <u>VEPU_swreg_87</u>        | 0x015c        | W           | 0x00000000         | Stabilization matrix4                      |
| <u>VEPU_swreg_88</u>        | 0x0160        | W           | 0x00000000         | Stabilization matrix5                      |
| <u>VEPU_swreg_89</u>        | 0x0164        | W           | 0x00000000         | Stabilization matrix6                      |
| <u>VEPU_swreg_90</u>        | 0x0168        | W           | 0x00000000         | Stabilization matrix7                      |
| <u>VEPU_swreg_91</u>        | 0x016c        | W           | 0x00000000         | Stabilization matrix8                      |
| <u>VEPU_swreg_92</u>        | 0x0170        | W           | 0x00000000         | Stabilization matrix9                      |
| <u>VEPU_swreg_93</u>        | 0x0174        | W           | 0x00000000         | the output of Stabilization motion sum     |
| <u>VEPU_swreg_94</u>        | 0x0178        | W           | 0x00000000         | output of Stabilization                    |
| <u>VEPU_swreg_95</u>        | 0x017c        | W           | 0x00000000         | RGB to YUV conversion coefficient register |
| <u>VEPU_swreg_96</u>        | 0x0180        | W           | 0x00000000         | RGB to YUV conversion coefficient register |
| <u>VEPU_swreg_97</u>        | 0x0184        | W           | 0x00000000         | RGB to YUV conversion coefficient register |
| <u>VEPU_swreg_98</u>        | 0x0188        | W           | 0x00000000         | RGA MASK                                   |
| <u>VEPU_swreg_99</u>        | 0x018c        | W           | 0x00000000         | mv related                                 |
| <u>VEPU_swreg_100_reuse</u> | 0x0190        | W           | 0x00000000         | QP register                                |
| <u>VEPU_swreg_101_read</u>  | 0x0194        | W           | 0x1f522780         | hw config reg                              |
| <u>VEPU_swreg_102</u>       | 0x0198        | W           | 0x00000000         | mvc related                                |

| Name                 | Offset | Size | Reset Value | Description                                                                                                                                                                                                                                                        |
|----------------------|--------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| VEPU_swreg_103       | 0x019c | W    | 0x00000000  | encoder start                                                                                                                                                                                                                                                      |
| VEPU_swreg_104       | 0x01a0 | W    | 0x00000000  | mb control register                                                                                                                                                                                                                                                |
| VEPU_swreg_105       | 0x01a4 | W    | 0x00000000  | swap ctrl register                                                                                                                                                                                                                                                 |
| VEPU_swreg_106_reuse | 0x01a8 | W    | 0x00000000  | encoder control register 1                                                                                                                                                                                                                                         |
| VEPU_swreg_107_reuse | 0x01ac | W    | 0x00000000  | JPEG control register                                                                                                                                                                                                                                              |
| VEPU_swreg_108_reuse | 0x01b0 | W    | 0x00000000  | intra slice bmp2                                                                                                                                                                                                                                                   |
| VEPU_swreg_109       | 0x01b4 | W    | 0x00001000  | encoder status                                                                                                                                                                                                                                                     |
| VEPU_swreg_110_read  | 0x01b8 | W    | 0x48311220  | product ID                                                                                                                                                                                                                                                         |
| VEPU_swreg_120_183   | 0x01e0 | W    | 0x00000000  | addr range :<br>0x01e0~0x02dcswreg120: DMV<br>4p/1p penalty table<br>valuesswreg121: DMV 4p/1p<br>penalty table valuesswreg122:<br>DMV 4p/1p penalty table<br>valuesswreg123: DMV 4p/1p<br>penalty table<br>values.....swreg183: DMV<br>4p/1p penalty table values |

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

#### 5.4.8 VEPU121 Detail Register Description

##### **VEPU\_swreg\_0**

Address: Operational Base + offset (0x0000)

| Bit   | Attr | Reset Value | Description                                    |
|-------|------|-------------|------------------------------------------------|
| 31:30 | RO   | 0x0         | reserved                                       |
| 29:16 | RW   | 0x0000      | vp8_pt1_qut_dc_y2<br>part 1 for qp quant dc y2 |
| 15:14 | RO   | 0x0         | reserved                                       |
| 13:0  | RW   | 0x0000      | vp8_pt1_qut_dc_y1<br>part1 for qp quant dc y1  |

##### **VEPU\_swreg\_1**

Address: Operational Base + offset (0x0004)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                 |
|------------|-------------|--------------------|----------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                           |
| 29:16      | RW          | 0x0000             | vp8_pt1_qut_ac_y1<br>part 1 for qp quant ac y1     |
| 15:14      | RO          | 0x0                | reserved                                           |
| 13:0       | RW          | 0x0000             | vp8_pt1_qut_dc_ch<br>part 1 for qp quant dc chroma |

**VEPU\_swreg\_2**

Address: Operational Base + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                 |
|------------|-------------|--------------------|----------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                           |
| 29:16      | RW          | 0x0000             | vp8_pt1_qut_ac_ch<br>part 1 for qp quant ac chroma |
| 15:14      | RO          | 0x0                | reserved                                           |
| 13:0       | RW          | 0x0000             | vp8_pt1_qut_ac_y2<br>part 1 for qp quant ac y2     |

**VEPU\_swreg\_3**

Address: Operational Base + offset (0x000c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                               |
|------------|-------------|--------------------|--------------------------------------------------|
| 31:27      | RO          | 0x0                | reserved                                         |
| 26:18      | RW          | 0x000              | vp8_pt1_zb_dc_ch<br>part 1 for qp zbin dc chroma |
| 17:9       | RW          | 0x000              | vp8_pt1_zb_dc_y2<br>part 1 for qp zbin dc y2     |
| 8:0        | RW          | 0x000              | vp8_pt1_zb_dc_y1<br>part 1 for qp zbin dc y1     |

**VEPU\_swreg\_4**

Address: Operational Base + offset (0x0010)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                               |
|------------|-------------|--------------------|--------------------------------------------------|
| 31:27      | RO          | 0x0                | reserved                                         |
| 26:18      | RW          | 0x000              | vp8_pt1_zb_ac_ch<br>part 1 for qp zbin ac chroma |
| 17:9       | RW          | 0x000              | vp8_pt1_zb_ac_y2<br>part 1 for qp zbin ac y2     |
| 8:0        | RW          | 0x000              | vp8_pt1_zb_ac_y1<br>part 1 for qp zbin ac y1     |

**VEPU\_swreg\_5**

Address: Operational Base + offset (0x0014)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                 |
|------------|-------------|--------------------|----------------------------------------------------|
| 31:24      | RO          | 0x0                | reserved                                           |
| 23:16      | RW          | 0x00               | vp8_pt1_rnd_dc_ch<br>part 1 for qp round dc chroma |
| 15:8       | RW          | 0x00               | vp8_pt1_rnd_dc_y2<br>part 1 for qp round dc y2     |
| 7:0        | RW          | 0x00               | vp8_pt1_rnd_dc_y1<br>part 1 for qp round dc y1     |

**VEPU\_swreg\_6**

Address: Operational Base + offset (0x0018)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                 |
|------------|-------------|--------------------|----------------------------------------------------|
| 31:24      | RO          | 0x0                | reserved                                           |
| 23:16      | RW          | 0x00               | vp8_pt1_rnd_ac_ch<br>part 1 for qp round ac chroma |
| 15:8       | RW          | 0x00               | vp8_pt1_rnd_ac_y2<br>part 1 for qp round ac y2     |
| 7:0        | RW          | 0x00               | vp8_pt1_rnd_ac_y1<br>part 1 for qp round ac y1     |

**VEPU\_swreg\_7**

Address: Operational Base + offset (0x001c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                     |
|------------|-------------|--------------------|--------------------------------------------------------|
| 31         | RO          | 0x0                | reserved                                               |
| 30:25      | RW          | 0x00               | vp8_pt1_filter_sel<br>VP8 part1 filter select          |
| 24:17      | RW          | 0x00               | vp8_pt1_dequt_dc_ch<br>part 1 for qp dequant dc chroma |
| 16:8       | RW          | 0x000              | vp8_pt1_deqnt_dc_y2<br>part 1 for qp dequant dc y2     |
| 7:0        | RW          | 0x00               | vp8_pt1_dequt_dc_y1<br>part 1 for qp dequant dc y1     |

**VEPU\_swreg\_8**

Address: Operational Base + offset (0x0020)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                     |
|------------|-------------|--------------------|--------------------------------------------------------|
| 31:27      | RO          | 0x0                | reserved                                               |
| 26:18      | RW          | 0x000              | vp8_pt1_dequt_ac_ch<br>part 1 for qp dequant ac chroma |
| 17:9       | RW          | 0x000              | vp8_pt1_dequt_ac_y2<br>part 1 for qp dequant ac y2     |
| 8:0        | RW          | 0x000              | vp8_pt1_dequt_ac_y1<br>part 1 for qp dequant ac y1     |

**VEPU\_swreg\_9**

Address: Operational Base + offset (0x0024)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                             |
|------------|-------------|--------------------|------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                       |
| 29:16      | RW          | 0x0000             | vp8_pt2_qut_dc_y2<br>part 2 for qp quant dc y2 |
| 15:14      | RO          | 0x0                | reserved                                       |
| 13:0       | RW          | 0x0000             | vp8_pt2_qut_dc_y1<br>part2 for qp quant dc y1  |

**VEPU\_swreg\_10**

Address: Operational Base + offset (0x0028)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                 |
|------------|-------------|--------------------|----------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                           |
| 29:16      | RW          | 0x0000             | vp8_pt2_qut_ac_y1<br>part 2 for qp quant ac y1     |
| 15:14      | RO          | 0x0                | reserved                                           |
| 13:0       | RW          | 0x0000             | vp8_pt2_qut_dc_ch<br>part 2 for qp quant dc chroma |

**VEPU\_swreg\_11**

Address: Operational Base + offset (0x002c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                 |
|------------|-------------|--------------------|----------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                           |
| 29:16      | RW          | 0x0000             | vp8_pt2_qut_ac_ch<br>part 2 for qp quant ac chroma |
| 15:14      | RO          | 0x0                | reserved                                           |
| 13:0       | RW          | 0x0000             | vp8_pt2_qut_ac_y2<br>part 2 for qp quant ac y2     |

**VEPU\_swreg\_12**

Address: Operational Base + offset (0x0030)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                               |
|------------|-------------|--------------------|--------------------------------------------------|
| 31:27      | RO          | 0x0                | reserved                                         |
| 26:18      | RW          | 0x000              | vp8_pt2_zb_dc_ch<br>part 2 for qp zbin dc chroma |
| 17:9       | RW          | 0x000              | vp8_pt2_zb_dc_y2<br>part 2 for qp zbin dc y2     |
| 8:0        | RW          | 0x000              | vp8_pt2_zb_dc_y1<br>part 2 for qp zbin dc y1     |

**VEPU\_swreg\_13**

Address: Operational Base + offset (0x0034)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                               |
|------------|-------------|--------------------|--------------------------------------------------|
| 31:27      | RO          | 0x0                | reserved                                         |
| 26:18      | RW          | 0x000              | vp8_pt2_zb_ac_ch<br>part 2 for qp zbin ac chroma |
| 17:9       | RW          | 0x000              | vp8_pt2_zb_ac_y2<br>part 2 for qp zbin ac y2     |
| 8:0        | RW          | 0x000              | vp8_pt2_zb_ac_y1<br>part2 for qp zbin ac y1      |

**VEPU\_swreg\_14**

Address: Operational Base + offset (0x0038)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                 |
|------------|-------------|--------------------|----------------------------------------------------|
| 31:24      | RO          | 0x0                | reserved                                           |
| 23:16      | RW          | 0x00               | vp8_pt2_rnd_dc_ch<br>part 2 for qp round dc chroma |
| 15:8       | RW          | 0x00               | vp8_pt2_rnd_dc_y2<br>part 2 for qp round dc y2     |
| 7:0        | RW          | 0x00               | vp8_pt2_rnd_dc_y1<br>part 2 for qp round dc y1     |

**VEPU\_swreg\_15**

Address: Operational Base + offset (0x003c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                 |
|------------|-------------|--------------------|----------------------------------------------------|
| 31:24      | RO          | 0x0                | reserved                                           |
| 23:16      | RW          | 0x00               | vp8_pt2_rnd_ac_ch<br>part 2 for qp round ac chroma |
| 15:8       | RW          | 0x00               | vp8_pt2_rnd_ac_y2<br>part 2 for qp round ac y2     |
| 7:0        | RW          | 0x00               | vp8_pt2_rnd_ac_y1<br>part 2 for qp round ac y1     |

**VEPU\_swreg\_16**

Address: Operational Base + offset (0x0040)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 31         | RO          | 0x0                | reserved                                             |
| 30:25      | RW          | 0x00               | vp8_pt2_filter_sel<br>VP8 part2 filter select        |
| 24:17      | RW          | 0x00               | vp8_pt2_dequt_dc_ch<br>part2 for qp dequnt dc chroma |
| 16:8       | RW          | 0x000              | vp8_pt2_deqnt_dc_y2<br>part 2 for qp dequnt dc y2    |
| 7:0        | RW          | 0x00               | vp8_pt2_dequt_dc_y1<br>part 2 for qp dequnt dc y1    |

**VEPU\_swreg\_17**

Address: Operational Base + offset (0x0044)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 31:27      | RO          | 0x0                | reserved                                             |
| 26:18      | RW          | 0x000              | vp8_pt2dequt_ac_ch<br>part 2 for qp dequnt ac chroma |
| 17:9       | RW          | 0x000              | vp8_pt2_dequt_ac_y2<br>part 2 for qp dequnt ac y2    |
| 8:0        | RW          | 0x000              | vp8_pt2_dequt_ac_y1<br>part2 for qp dequnt ac y1     |

**VEPU\_swreg\_18**

Address: Operational Base + offset (0x0048)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                             |
|------------|-------------|--------------------|------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                       |
| 29:16      | RW          | 0x0000             | vp8_pt3_qut_dc_y2<br>part 3 for qp quant dc y2 |
| 15:14      | RO          | 0x0                | reserved                                       |
| 13:0       | RW          | 0x0000             | vp8_pt3_qut_dc_y1<br>part3 for qp quant dc y1  |

**VEPU\_swreg\_19**

Address: Operational Base + offset (0x004c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                 |
|------------|-------------|--------------------|----------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                           |
| 29:16      | RW          | 0x0000             | vp8_pt3_qut_ac_y1<br>part 3 for qp quant ac y1     |
| 15:14      | RO          | 0x0                | reserved                                           |
| 13:0       | RW          | 0x0000             | vp8_pt3_qut_dc_ch<br>part 3 for qp quant dc chroma |

**VEPU\_swreg\_20**

Address: Operational Base + offset (0x0050)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                 |
|------------|-------------|--------------------|----------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                           |
| 29:16      | RW          | 0x0000             | vp8_pt3_qut_ac_ch<br>part 3 for qp quant ac chroma |
| 15:14      | RO          | 0x0                | reserved                                           |
| 13:0       | RW          | 0x0000             | vp8_pt3_qut_ac_y2<br>part 3 for qp quant ac y2     |

**VEPU\_swreg\_21**

Address: Operational Base + offset (0x0054)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                               |
|------------|-------------|--------------------|--------------------------------------------------|
| 31:27      | RO          | 0x0                | reserved                                         |
| 26:18      | RW          | 0x000              | vp8_pt3_zb_dc_ch<br>part 3 for qp zbin dc chroma |
| 17:9       | RW          | 0x000              | vp8_pt3_zb_dc_y2<br>part 3 for qp zbin dc y2     |
| 8:0        | RW          | 0x000              | vp8_pt3_zb_dc_y1<br>part 3 for qp zbin dc y1     |

**VEPU\_swreg\_22**

Address: Operational Base + offset (0x0058)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                               |
|------------|-------------|--------------------|--------------------------------------------------|
| 31:27      | RO          | 0x0                | reserved                                         |
| 26:18      | RW          | 0x000              | vp8_pt3_zb_ac_ch<br>part 3 for qp zbin ac chroma |
| 17:9       | RW          | 0x000              | vp8_pt3_zb_ac_y2<br>part 3 for qp zbin ac y2     |
| 8:0        | RW          | 0x000              | vp8_pt3_zb_ac_y1<br>part 3 for qp zbin ac y1     |

**VEPU\_swreg\_23**

Address: Operational Base + offset (0x005c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                 |
|------------|-------------|--------------------|----------------------------------------------------|
| 31:24      | RO          | 0x0                | reserved                                           |
| 23:16      | RW          | 0x00               | vp8_pt3_rnd_dc_ch<br>part 3 for qp round dc chroma |
| 15:8       | RW          | 0x00               | vp8_pt3_rnd_dc_y2<br>part 3 for qp round dc y2     |
| 7:0        | RW          | 0x00               | vp8_pt3_rnd_dc_y1<br>part 3 for qp round dc y1     |

**VEPU\_swreg\_24**

Address: Operational Base + offset (0x0060)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                 |
|------------|-------------|--------------------|----------------------------------------------------|
| 31:24      | RO          | 0x0                | reserved                                           |
| 23:16      | RW          | 0x00               | vp8_pt3_rnd_ac_ch<br>part 3 for qp round ac chroma |
| 15:8       | RW          | 0x00               | vp8_pt3_rnd_ac_y2<br>part 3 for qp round ac y2     |
| 7:0        | RW          | 0x00               | vp8_pt3_rnd_ac_y1<br>part 3 for qp round ac y1     |

**VEPU\_swreg\_25**

Address: Operational Base + offset (0x0064)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                    |
|------------|-------------|--------------------|-------------------------------------------------------|
| 31         | RO          | 0x0                | reserved                                              |
| 30:25      | RW          | 0x00               | vp8_pt3_filter_sel<br>VP8 part3 filter select         |
| 24:17      | RW          | 0x00               | vp8_pt3_dequt_dc_ch<br>part 3 for qp dequnt dc chroma |
| 16:8       | RW          | 0x000              | vp8_pt3_deqnt_dc_y2<br>part 3 for qp dequnt dc y2     |
| 7:0        | RW          | 0x00               | vp8_pt3_dequt_dc_y1<br>part 3 for qp dequnt dc y1     |

**VEPU\_swreg\_26**

Address: Operational Base + offset (0x0068)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                    |
|------------|-------------|--------------------|-------------------------------------------------------|
| 31:27      | RO          | 0x0                | reserved                                              |
| 26:18      | RW          | 0x000              | vp8_pt3_dequt_ac_ch<br>part 3 for qp dequnt ac chroma |
| 17:9       | RW          | 0x000              | vp8_pt3_dequt_ac_y2<br>part 3 for qp dequnt ac y2     |
| 8:0        | RW          | 0x000              | vp8_pt3_dequt_ac_y1<br>part 3 for qp dequnt ac y1     |

**VEPU\_swreg\_27**

Address: Operational Base + offset (0x006c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | vp8_seg_st_adres<br>11st quantization for jpeg chr/ VP8 segment start address |

**VEPU\_swreg\_28**

Address: Operational Base + offset (0x0070)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                 |
|------------|-------------|--------------------|----------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                           |
| 27:16      | RW          | 0x000              | vp8_imp_4x4_1<br>VP8 intra penalty for 4x4 1st sel |
| 15:12      | RO          | 0x0                | reserved                                           |
| 11:0       | RW          | 0x000              | vp8_imp_4x4_0<br>VP8 intra penalty for 4x4 0st sel |

**VEPU\_swreg\_29**

Address: Operational Base + offset (0x0074)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                 |
|------------|-------------|--------------------|----------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                           |
| 27:16      | RW          | 0x000              | vp8_imp_4x4_3<br>VP8 intra penalty for 4x4 3st sel |
| 15:12      | RO          | 0x0                | reserved                                           |
| 11:0       | RW          | 0x000              | vp8_imp_4x4_2<br>VP8 intra penalty for 4x4 2st sel |

**VEPU\_swreg\_30**

Address: Operational Base + offset (0x0078)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                 |
|------------|-------------|--------------------|----------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                           |
| 27:16      | RW          | 0x000              | vp8_imp_4x4_5<br>VP8 intra penalty for 4x4 5st sel |
| 15:12      | RO          | 0x0                | reserved                                           |
| 11:0       | RW          | 0x000              | vp8_imp_4x4_4<br>VP8 intra penalty for 4x4 4st sel |

**VEPU\_swreg\_31**

Address: Operational Base + offset (0x007c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                 |
|------------|-------------|--------------------|----------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                           |
| 27:16      | RW          | 0x000              | vp8_imp_4x4_7<br>VP8 intra penalty for 4x4 7st sel |
| 15:12      | RO          | 0x0                | reserved                                           |
| 11:0       | RW          | 0x000              | vp8_imp_4x4_6<br>VP8 intra penalty for 4x4 6st sel |

**VEPU\_swreg\_32**

Address: Operational Base + offset (0x0080)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                 |
|------------|-------------|--------------------|----------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                           |
| 27:16      | RW          | 0x000              | vp8_imp_4x4_9<br>VP8 intra penalty for 4x4 9st sel |
| 15:12      | RO          | 0x0                | reserved                                           |
| 11:0       | RW          | 0x000              | vp8_imp_4x4_8<br>VP8 intra penalty for 4x4 8st sel |

**VEPU\_swreg\_33**

Address: Operational Base + offset (0x0084)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                     |
|------------|-------------|--------------------|--------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                               |
| 27:16      | RW          | 0x000              | vp8_imp_16x16_1<br>VP8 intra penalty for 16x16 1st sel |
| 15:12      | RO          | 0x0                | reserved                                               |
| 11:0       | RW          | 0x000              | vp8_imp_16x16_0<br>VP8 intra penalty for 16x16 0st sel |

**VEPU swreg 34**

Address: Operational Base + offset (0x0088)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                     |
|------------|-------------|--------------------|--------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                               |
| 27:16      | RW          | 0x000              | vp8_imp_16x16_3<br>VP8 intra penalty for 16x16 3st sel |
| 15:12      | RO          | 0x0                | reserved                                               |
| 11:0       | RW          | 0x000              | vp8_imp_16x16_2<br>VP8 intra penalty for 16x16 2st sel |

**VEPU swreg 40**

Address: Operational Base + offset (0x00a0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                            |
|------------|-------------|--------------------|---------------------------------------------------------------|
| 31         | RO          | 0x0                | reserved                                                      |
| 30:24      | RW          | 0x00               | vp8_lpf_bpred<br>The bpred of loop filter for vp8             |
| 23         | RO          | 0x0                | reserved                                                      |
| 22:16      | RW          | 0x00               | vp8_lpf_intra<br>The intra macro block of loop filter for vp8 |
| 15:12      | RO          | 0x0                | reserved                                                      |
| 11:0       | RW          | 0x000              | vp8_inter_type<br>inter type for vp8                          |

**VEPU swreg 41**

Address: Operational Base + offset (0x00a4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                         |
|------------|-------------|--------------------|------------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                   |
| 27:16      | RW          | 0x000              | vp8_coef_dmv_ply<br>The coefficient of dmv penalty for VP8 |
| 15:12      | RO          | 0x0                | reserved                                                   |
| 11:0       | RW          | 0x000              | vp8_ref_frame<br>The reference frame for vp8               |

**VEPU swreg 42**

Address: Operational Base + offset (0x00a8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                      |
|------------|-------------|--------------------|---------------------------------------------------------|
| 31:23      | RO          | 0x0                | reserved                                                |
| 22:16      | RW          | 0x00               | vp8_lpf_altref<br>loop filter for alt reference frame   |
| 15         | RO          | 0x0                | reserved                                                |
| 14:8       | RW          | 0x00               | vp8_lpf_lastref<br>loop filter for last reference frame |
| 7          | RO          | 0x0                | reserved                                                |
| 6:0        | RW          | 0x00               | vp8_lpf_orgref<br>loop filter for reference frame       |

**VEPU swreg 43**

Address: Operational Base + offset (0x00ac)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                     |
|------------|-------------|--------------------|--------------------------------------------------------|
| 31:23      | RO          | 0x0                | reserved                                               |
| 22:16      | RW          | 0x00               | vp8_lpf_divmv<br>loop filter for divide mv used in vp8 |
| 15         | RO          | 0x0                | reserved                                               |
| 14:8       | RW          | 0x00               | vp8_lpf_zeromv<br>loop filter for zero mv used in vp8  |
| 7          | RO          | 0x0                | reserved                                               |
| 6:0        | RW          | 0x00               | vp8_lpf_newmv<br>loop filter for new mv used in vp8    |

**VEPU swreg 44**

Address: Operational Base + offset (0x00b0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | intra_slice bmp0<br>bit0 : slices0<br>bit1 : slices1<br>bit2 : slices2<br>.....<br>bit31 : slices31 |

**VEPU swreg 45**

Address: Operational Base + offset (0x00b4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                     |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | intra_slice bmp1<br>bit0 : slices32<br>bit1 : slices33<br>bit2 : slices34<br>.....<br>bit31 : slices63 |

**VEPU\_swreg\_46**

Address: Operational Base + offset (0x00b8)

| Bit   | Attr | Reset Value | Description                                                              |
|-------|------|-------------|--------------------------------------------------------------------------|
| 31:24 | RW   | 0x00        | intra_up_mb_area<br>The top intra macro block's area used in row         |
| 23:16 | RW   | 0x00        | intra_down_mb_area<br>The bottom intra macro block's area used in row    |
| 15:8  | RW   | 0x00        | intra_left_mb_area<br>The left intra macro block's area used in column   |
| 7:0   | RW   | 0x00        | intra_right_mb_area<br>The right intra macro block's area used in column |

**VEPU\_swreg\_47**

Address: Operational Base + offset (0x00bc)

| Bit   | Attr | Reset Value | Description                                                 |
|-------|------|-------------|-------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | cir_first_intra<br>0:disable<br>other:enable and be set     |
| 15:0  | RW   | 0x0000      | cir_intra_mb_itvl<br>0: disable<br>other: enable and be set |

**VEPU\_swreg\_48**

Address: Operational Base + offset (0x00c0)

| Bit  | Attr | Reset Value | Description                                 |
|------|------|-------------|---------------------------------------------|
| 31:0 | RW   | 0x00000000  | luma_in_st_addr<br>input luma start address |

**VEPU\_swreg\_49**

Address: Operational Base + offset (0x00c4)

| Bit  | Attr | Reset Value | Description                             |
|------|------|-------------|-----------------------------------------|
| 31:0 | RW   | 0x00000000  | cb_in_st_addr<br>input cb start address |

**VEPU\_swreg\_50**

Address: Operational Base + offset (0x00c8)

| Bit  | Attr | Reset Value | Description                             |
|------|------|-------------|-----------------------------------------|
| 31:0 | RW   | 0x00000000  | cr_in_st_addr<br>input cr start address |

**VEPU\_swreg\_51**

Address: Operational Base + offset (0x00cc)

| Bit  | Attr | Reset Value | Description                                                       |
|------|------|-------------|-------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | strm_header_left_hbits<br>the high 32 bit of stram header be left |

**VEPU\_swreg\_52**

Address: Operational Base + offset (0x00d0)

| Bit  | Attr | Reset Value | Description                                                      |
|------|------|-------------|------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | strm_header_left_lbits<br>the low 32 bit of stram header be left |

**VEPU\_swreg\_53**

Address: Operational Base + offset (0x00d4)

| Bit  | Attr | Reset Value | Description                                        |
|------|------|-------------|----------------------------------------------------|
| 31:0 | RW   | 0x00000000  | strm_bufsize_lmt<br>the limit size of steam buffer |

**VEPU\_swreg\_54**

Address: Operational Base + offset (0x00d8)

| Bit   | Attr | Reset Value | Description                                                              |
|-------|------|-------------|--------------------------------------------------------------------------|
| 31:24 | RW   | 0x01        | axi_rd_id<br>if config 0,it will be modify as 1 by HW auto               |
| 23:16 | RW   | 0x01        | axi_wr_id<br>if config 0,it will be modify as 1 by HW auto               |
| 15:14 | RO   | 0x0         | reserved                                                                 |
| 13:8  | RW   | 0x00        | burst_len<br>burst length                                                |
| 7:3   | RO   | 0x0         | reserved                                                                 |
| 2     | RW   | 0x0         | burst_incr_mod_sel<br>0: single burst selected<br>1: incr burst selected |
| 1     | RW   | 0x0         | burst_discard<br>0:disable ,off<br>1:enable,on                           |
| 0     | RW   | 0x0         | burst_disable<br>0: enable<br>1:disable                                  |

**VEPU\_swreg\_55**

Address: Operational Base + offset (0x00dc)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                |
|------------|-------------|--------------------|---------------------------------------------------|
| 31:16      | RO          | 0x0                | reserved                                          |
| 15:12      | RW          | 0x0                | roi_dlt_qp1<br>1st for delta qp for roi           |
| 11:8       | RW          | 0x0                | roi_dlt_qp2<br>2st for delta qp for roi           |
| 7:4        | RO          | 0x0                | reserved                                          |
| 3:0        | RW          | 0x0                | qp_adst<br>signed register;<br>range from -8 to 7 |

**VEPU\_swreg\_56**

Address: Operational Base + offset (0x00e0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                        |
|------------|-------------|--------------------|-----------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | luma_ref_st_adr<br>the luma reference frame start address |

**VEPU\_swreg\_57**

Address: Operational Base + offset (0x00e4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                            |
|------------|-------------|--------------------|---------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | chroma_ref_st_adr<br>the chroma reference frame start address |

**VEPU\_swreg\_58**

Address: Operational Base + offset (0x00e8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                      |
|------------|-------------|--------------------|-----------------------------------------|
| 31:11      | RW          | 0x0000000          | qp_sum_div2<br>the result of (qp sum)/2 |
| 10:0       | RO          | 0x0                | reserved                                |

**VEPU\_swreg\_59**

Address: Operational Base + offset (0x00ec)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------|
| 31:29      | RO          | 0x0                | reserved                                                                                |
| 28         | RW          | 0x0                | h264_qurt_pixmv_dis<br>1:disable<br>0:default,enable                                    |
| 27:26      | RO          | 0x0                | reserved                                                                                |
| 25:24      | RW          | 0x0                | dblking_flt_mode<br>0 : enabled<br>1 : disabled<br>2 : disabled on slice ( vp8=simple ) |
| 23         | RO          | 0x0                | reserved                                                                                |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------|
| 22:21      | RW          | 0x0                | h264_cabac_idc<br>0,1,2: used<br>3: no use                                                  |
| 20         | RW          | 0x0                | entry_code_fmt<br>h.264:<br>0: cavlc<br>1: cabac<br>VP8:boolenc enable                      |
| 19:18      | RO          | 0x0                | reserved                                                                                    |
| 17         | RW          | 0x0                | h264_trfmod_8x8<br>on-off for 8x8 transform used in h264                                    |
| 16         | RW          | 0x0                | h264_res_intermod_4x4<br>the restriction inter mode selected in 4x4 block                   |
| 15         | RW          | 0x0                | h264_strm_mod_sel<br>0 : NAL unit ;<br>1 : BYTE                                             |
| 14:8       | RW          | 0x00               | h264_slice_num<br>0=one slice in current picture<br>1=two slice in current picture<br>..... |
| 7:0        | RO          | 0x0                | reserved                                                                                    |

**VEPU\_swreg\_60**

Address: Operational Base + offset (0x00f0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------|
| 31:22      | RO          | 0x0                | reserved                                                                          |
| 21:16      | RW          | 0x00               | strm_st_offset                                                                    |
| 15:8       | RW          | 0x00               | skip_mb_mode<br>H.264:SKIP macroblock mode<br>VP8 :zero/nearest/near mode penalty |
| 7:6        | RO          | 0x0                | reserved                                                                          |
| 5:4        | RW          | 0x0                | right_spill<br>div4 value<br>range:0~3                                            |
| 3:0        | RW          | 0x0                | bot_spill<br>the bottom edge of image for spill pixels                            |

**VEPU\_swreg\_61**

Address: Operational Base + offset (0x00f4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>            |
|------------|-------------|--------------------|-------------------------------|
| 31:23      | RO          | 0x0                | reserved                      |
| 22:20      | RW          | 0x0                | offset_in_chroma<br>byte unit |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>          |
|------------|-------------|--------------------|-----------------------------|
| 19         | RO          | 0x0                | reserved                    |
| 18:16      | RW          | 0x0                | offset_in_luma<br>byte unit |
| 15:14      | RO          | 0x0                | reserved                    |
| 13:0       | RW          | 0x0000             | row_len_in_luma             |

**VEPU\_swreg\_62**

Address: Operational Base + offset (0x00f8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b> |
|------------|-------------|--------------------|--------------------|
| 31:22      | RO          | 0x0                | reserved           |
| 21:0       | RW          | 0x0000000          | rlc_sum<br>rlc_sum |

**VEPU\_swreg\_63**

Address: Operational Base + offset (0x00fc)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                        |
|------------|-------------|--------------------|-----------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | recon_luma_st_adr<br>the reconstructed luma start address |

**VEPU\_swreg\_64**

Address: Operational Base + offset (0x0100)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                            |
|------------|-------------|--------------------|---------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | recon_chroma_st_adr<br>the reconstructed chroma start address |

**VEPU\_swreg\_65\_reuse**

Address: Operational Base + offset (0x0104)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                          |
|------------|-------------|--------------------|-------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | h264_chkpt_1<br>1st word used for check point used in h.264 |
| 15:0       | RW          | 0x0000             | h264_chkpt_2<br>2st word used for check point used in h.264 |

**VEPU\_swreg\_66\_reuse**

Address: Operational Base + offset (0x0108)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                          |
|------------|-------------|--------------------|-------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | h264_chkpt_3<br>3st word used for check point used in h.264 |
| 15:0       | RW          | 0x0000             | h264_chkpt_4<br>4st word used for check point used in h.264 |

**VEPU\_swreg\_67\_reuse**

Address: Operational Base + offset (0x010c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                          |
|------------|-------------|--------------------|-------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | h264_chkpt_5<br>5st word used for check point used in h.264 |
| 15:0       | RW          | 0x0000             | h264_chkpt_6<br>6st word used for check point used in h.264 |

**VEPU swreg 68 reuse**

Address: Operational Base + offset (0x0110)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                          |
|------------|-------------|--------------------|-------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | h264_chkpt_7<br>7st word used for check point used in h.264 |
| 15:0       | RW          | 0x0000             | h264_chkpt_8<br>8st word used for check point used in h.264 |

**VEPU swreg 69 reuse**

Address: Operational Base + offset (0x0114)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                            |
|------------|-------------|--------------------|---------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | h264_chkpt_9<br>9st word used for check point used in h.264   |
| 15:0       | RW          | 0x0000             | h264_chkpt_10<br>10st word used for check point used in h.264 |

**VEPU swreg 70 reuse**

Address: Operational Base + offset (0x0118)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                          |
|------------|-------------|--------------------|-------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | h264_errchkpt_1<br>1st word error check point used in h.264 |
| 15:0       | RW          | 0x0000             | h264_errchkpt_2<br>2st word error check point used in h.264 |

**VEPU swreg 71 reuse**

Address: Operational Base + offset (0x011c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                          |
|------------|-------------|--------------------|-------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | h264_errchkpt_3<br>3st word error check point used in h.264 |
| 15:0       | RW          | 0x0000             | h264_errchkpt_4<br>4st word error check point used in h.264 |

**VEPU swreg 72 reuse**

Address: Operational Base + offset (0x0120)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                          |
|------------|-------------|--------------------|-------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | h264_errchkpt_5<br>5st word error check point used in h.264 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                          |
|------------|-------------|--------------------|-------------------------------------------------------------|
| 15:0       | RW          | 0x0000             | h264_errchkpt_6<br>6st word error check point used in h.264 |

**VEPU swreg 73 reuse**

Address: Operational Base + offset (0x0124)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                      |
|------------|-------------|--------------------|-----------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                |
| 27:24      | RW          | 0x0                | chkqp_1<br>1st for delta qp check point |
| 23:20      | RW          | 0x0                | chkqp_2<br>2st for delta qp check point |
| 19:16      | RW          | 0x0                | chkqp_3<br>3st for delta qp check point |
| 15:12      | RW          | 0x0                | chkqp_4<br>4st for delta qp check point |
| 11:8       | RW          | 0x0                | chkqp_5<br>5st for delta qp check point |
| 7:4        | RW          | 0x0                | chkqp_6<br>6st for delta qp check point |
| 3:0        | RW          | 0x0                | chkqp_7<br>7st for delta qp check point |

**VEPU swreg 74**

Address: Operational Base + offset (0x0128)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                                                                          |
| 29:24      | RW          | 0x00               | mad_thsld<br>value = (MAD threshold)/256                                                          |
| 23:16      | RW          | 0x00               | encoderd_slices<br>the number of encoder slices which used in h.264                               |
| 15:8       | RO          | 0x0                | reserved                                                                                          |
| 7:4        | RW          | 0x0                | img_fmt_in<br>YUV420P<br>YUV420SP<br>YUV422<br>UYVY422<br>RGB565<br>RGB444<br>RGB888<br>RGB101010 |
| 3:2        | RW          | 0x0                | img_in_rot<br>0 : no rotation<br>1 : rotate right 90 degress<br>2 : rotate left 90 degress        |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                 |
|------------|-------------|--------------------|----------------------------------------------------|
| 1          | RO          | 0x0                | reserved                                           |
| 0          | RW          | 0x0                | nal_mode<br>the output of NAL size to base control |

**VEPU\_swreg\_75**

Address: Operational Base + offset (0x012c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | intramod_16x16                                                         |
| 15:0       | RW          | 0x0000             | intermod<br>the intra/inter selection for inter macro block mode favor |

**VEPU\_swreg\_76\_reuse**

Address: Operational Base + offset (0x0130)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------|
| 31:26      | RW          | 0x00               | pps_init_qp<br>pps init qp in picture used in h264<br>range : 0~51                  |
| 25:22      | RW          | 0x0                | slice_flt_alpha<br>offset div2<br>range : -6~6                                      |
| 21:18      | RW          | 0x0                | slice_flt_beta<br>config value = (real value)/2<br>signed register<br>range : -6 ~6 |
| 17:13      | RW          | 0x00               | qp_offset_ch<br>signed register<br>range : -12~12                                   |
| 12:9       | RO          | 0x0                | reserved                                                                            |
| 8          | RW          | 0x0                | sw_qpass                                                                            |
| 7:5        | RO          | 0x0                | reserved                                                                            |
| 4:1        | RW          | 0x0                | idr_picid<br>IDR pic ID                                                             |
| 0          | RW          | 0x0                | constr_intra_pred<br>constrained intra prediction                                   |

**VEPU\_swreg\_77**

Address: Operational Base + offset (0x0134)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                 |
|------------|-------------|--------------------|----------------------------------------------------|
| 31:0       | RW          | 0x00000000         | output_strm_st_addr<br>output stream start address |

**VEPU\_swreg\_78**

Address: Operational Base + offset (0x0138)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                 |
|------------|-------------|--------------------|----------------------------------------------------|
| 31:0       | RW          | 0x00000000         | output_ctrl_st_adr<br>output control start address |

**VEPU\_swreg\_79**

Address: Operational Base + offset (0x013c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | next_luma_st_adr<br>next picture luminance start address |

**VEPU\_swreg\_80**

Address: Operational Base + offset (0x0140)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b> |
|------------|-------------|--------------------|--------------------|
| 31:0       | RW          | 0x00000000         | mv_out_st_adr      |

**VEPU\_swreg\_81**

Address: Operational Base + offset (0x0144)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | cabac_table_st_adr<br>H264: cabac table<br>VP8 : probability tables |

**VEPU\_swreg\_82**

Address: Operational Base + offset (0x0148)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 31:24      | RW          | 0x00               | first_roi_tmb<br>(inside area)                           |
| 23:16      | RW          | 0x00               | first_roi_bmb<br>(outside area)                          |
| 15:8       | RW          | 0x00               | first_roi_lmb<br>qp=qp + roi1_Delta_Qp<br>(inside area)  |
| 7:0        | RW          | 0x00               | first_roi_rmb<br>qp=qp - roi1_Delta_Qp<br>(outside area) |

**VEPU\_swreg\_83**

Address: Operational Base + offset (0x014c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>               |
|------------|-------------|--------------------|----------------------------------|
| 31:24      | RW          | 0x00               | second_roi_rmb<br>(inside area)  |
| 23:16      | RW          | 0x00               | second_roi_bmb<br>(outside area) |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                        |
|------------|-------------|--------------------|-----------------------------------------------------------|
| 15:8       | RW          | 0x00               | second_roi_lmb<br>qp=qp + roi1_Delta_Qp<br>(inside area)  |
| 7:0        | RW          | 0x00               | second_roi_tmb<br>qp=qp - roi1_Delta_Qp<br>(outside area) |

**VEPU\_swreg\_84**

Address: Operational Base + offset (0x0150)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                  |
|------------|-------------|--------------------|-------------------------------------|
| 31:24      | RO          | 0x0                | reserved                            |
| 23:0       | RW          | 0x000000           | stab_matrix1<br>(position@ up-left) |

**VEPU\_swreg\_85**

Address: Operational Base + offset (0x0154)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>              |
|------------|-------------|--------------------|---------------------------------|
| 31:24      | RO          | 0x0                | reserved                        |
| 23:0       | RW          | 0x000000           | stab_matrix2<br>(position @ up) |

**VEPU\_swreg\_86**

Address: Operational Base + offset (0x0158)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:24      | RO          | 0x0                | reserved                             |
| 23:0       | RW          | 0x000000           | stab_matrix3<br>(position @up-right) |

**VEPU\_swreg\_87**

Address: Operational Base + offset (0x015c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                |
|------------|-------------|--------------------|-----------------------------------|
| 31:24      | RO          | 0x0                | reserved                          |
| 23:0       | RW          | 0x000000           | stab_matrix4<br>(position @ left) |

**VEPU\_swreg\_88**

Address: Operational Base + offset (0x0160)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>               |
|------------|-------------|--------------------|----------------------------------|
| 31:24      | RO          | 0x0                | reserved                         |
| 23:0       | RW          | 0x000000           | stab_matrix5<br>(position @GMV ) |

**VEPU\_swreg\_89**

Address: Operational Base + offset (0x0164)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                |
|------------|-------------|--------------------|-----------------------------------|
| 31:24      | RO          | 0x0                | reserved                          |
| 23:0       | RW          | 0x000000           | stab_matrix6<br>(position@right ) |

**VEPU\_swreg\_90**

Address: Operational Base + offset (0x0168)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:24      | RO          | 0x0                | reserved                             |
| 23:0       | RW          | 0x000000           | stab_matrix7<br>(position@down-left) |

**VEPU\_swreg\_91**

Address: Operational Base + offset (0x016c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>               |
|------------|-------------|--------------------|----------------------------------|
| 31:24      | RO          | 0x0                | reserved                         |
| 23:0       | RW          | 0x000000           | stab_matrix8<br>(position@down ) |

**VEPU\_swreg\_92**

Address: Operational Base + offset (0x0170)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                 |
|------------|-------------|--------------------|----------------------------------------------------|
| 31:26      | RW          | 0x00               | stab_gmv_vrtl<br>signed register<br>range : -16~16 |
| 25:24      | RO          | 0x0                | reserved                                           |
| 23:0       | RW          | 0x000000           | stab_matrix9<br>(position@down-right )             |

**VEPU\_swreg\_93**

Address: Operational Base + offset (0x0174)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | stab_motion_sum<br>read value = (real value)/8<br>range : 0~1089*253*255*53/8 |

**VEPU\_swreg\_94**

Address: Operational Base + offset (0x0178)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                      |
|------------|-------------|--------------------|-----------------------------------------|
| 31:8       | RW          | 0x000000           | stab_min_value<br>range : 0~255*253*253 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                               |
|------------|-------------|--------------------|------------------------------------------------------------------|
| 7:6        | RW          | 0x0                | stab_mod_sel<br>0 : disabled<br>1 : stab only<br>2 : stab+encode |
| 5:0        | RW          | 0x00               | stab_hor_gmv<br>signed register<br>range : -16~16                |

**VEPU\_swreg\_95**

Address: Operational Base + offset (0x017c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                           |
|------------|-------------|--------------------|--------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | rgb2yuv_coe2<br>the 2st conversion coefficien for RGB to YUV |
| 15:0       | RW          | 0x0000             | rgb2yuv_coe1<br>the 1st conversion coefficien for RGB to YUV |

**VEPU\_swreg\_96**

Address: Operational Base + offset (0x0180)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                           |
|------------|-------------|--------------------|--------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | rgb2yuv_coe5<br>the 5st conversion coefficien for RGB to YUV |
| 15:0       | RW          | 0x0000             | rgb2yuv_coe3<br>the 3st conversion coefficien for RGB to YUV |

**VEPU\_swreg\_97**

Address: Operational Base + offset (0x0184)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                           |
|------------|-------------|--------------------|--------------------------------------------------------------|
| 31:16      | RO          | 0x0                | reserved                                                     |
| 15:0       | RW          | 0x0000             | rgb2yuv_coe6<br>the 6st conversion coefficien for RGB to YUV |

**VEPU\_swreg\_98**

Address: Operational Base + offset (0x0188)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                  |
|------------|-------------|--------------------|-------------------------------------|
| 31:21      | RO          | 0x0                | reserved                            |
| 20:16      | RW          | 0x00               | bcmpt_mask_position<br>range : 0~31 |
| 15:13      | RO          | 0x0                | reserved                            |
| 12:8       | RW          | 0x00               | gcmpt_mask_position<br>range : 0~31 |
| 7:5        | RO          | 0x0                | reserved                            |
| 4:0        | RW          | 0x00               | rcmpt_mask_position<br>range : 0~31 |

**VEPU\_swreg\_99**

Address: Operational Base + offset (0x018c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                        |
|------------|-------------|--------------------|-----------------------------------------------------------|
| 31         | RO          | 0x0                | reserved                                                  |
| 30:21      | RW          | 0x000              | mv_1p_ply<br>differential MV penalty for 1p               |
| 20:11      | RW          | 0x000              | mv_1p_4p_ply<br>ME. DMVPenaltyQp                          |
| 10:1       | RW          | 0x000              | mv_4p_ply                                                 |
| 0          | RW          | 0x0                | mutimv_en<br>on-off flag for using exceed one mv every mb |

**VEPU\_swreg\_100\_reuse**

Address: Operational Base + offset (0x0190)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                         |
|------------|-------------|--------------------|------------------------------------------------------------|
| 31:26      | RW          | 0x00               | h264_init_luma_qp<br>range: 0~51                           |
| 25:20      | RW          | 0x00               | h264_max_qp<br>range : 0~51                                |
| 19:14      | RW          | 0x00               | h264_min_qp<br>range:0~51                                  |
| 13         | RO          | 0x0                | reserved                                                   |
| 12:0       | RW          | 0x0000             | h264_chkpt_distance<br>checkpoint distance for macro block |

**VEPU\_swreg\_101\_read**

Address: Operational Base + offset (0x0194)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                     |
|------------|-------------|--------------------|----------------------------------------|
| 31:12      | RO          | 0x1f522            | HW_CONFIG<br>Field0000 Description     |
| 11:0       | RO          | 0x780              | MAX_VID_WIDTH<br>Field0000 Description |

**VEPU\_swreg\_102**

Address: Operational Base + offset (0x0198)

| Bit   | Attr | Reset Value | Description                                 |
|-------|------|-------------|---------------------------------------------|
| 31:24 | RO   | 0x0         | reserved                                    |
| 23:20 | RW   | 0x0         | mv_favor_16x16<br>value = (real value)/2.   |
| 19:11 | RW   | 0x000       | mv_ply_4x4                                  |
| 10:8  | RW   | 0x0         | mvc_view_id                                 |
| 7     | RW   | 0x0         | mvc_anchor_pic_flag                         |
| 6:4   | RW   | 0x0         | mvc_priority_id                             |
| 3:1   | RW   | 0x0         | mvc_temporal_id                             |
| 0     | RW   | 0x0         | mvc_inter_view_flag<br>MVC inter_view_flag. |

**VEPU\_swreg\_103**

Address: Operational Base + offset (0x019c)

| Bit   | Attr | Reset Value | Description                                                                                  |
|-------|------|-------------|----------------------------------------------------------------------------------------------|
| 31:29 | RO   | 0x0         | reserved                                                                                     |
| 28:20 | RW   | 0x000       | enc_height<br>lum height (macroblock unit)<br>H264: [6..255]<br>JPEG: [6..511]               |
| 19:17 | RO   | 0x0         | reserved                                                                                     |
| 16:8  | RW   | 0x000       | enc_width<br>lum width (macroblock unit)<br>H264:<br>range : 9~255<br>JPEG:<br>range : 6~511 |
| 7:6   | RW   | 0x0         | enc_frame_type<br>0: INTER<br>1: INTRA(IDR)<br>2: MVC-INTER                                  |
| 5:4   | RW   | 0x0         | enc_fmt<br>1 : VP8,<br>2 : JPEG<br>3 : H264                                                  |
| 3:1   | RO   | 0x0         | reserved                                                                                     |
| 0     | RW   | 0x0         | enc_en<br>encoder enable                                                                     |

**VEPU\_swreg\_104**

Address: Operational Base + offset (0x01a0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>           |
|------------|-------------|--------------------|------------------------------|
| 31:16      | RW          | 0x0000             | mb_count_out<br>mb_count_out |
| 15:0       | RW          | 0x0000             | mb_cnt<br>macroblock_count   |

**VEPU\_swreg\_105**

Address: Operational Base + offset (0x01a4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                        |
|------------|-------------|--------------------|-------------------------------------------|
| 31         | RW          | 0x0                | swap8_in<br>0: no swap<br>1: swap 8bit    |
| 30         | RW          | 0x0                | swap16_in<br>0: no swap<br>1: swap 16bit  |
| 29         | RW          | 0x0                | swap32_in<br>0: no swap<br>1: swap 32bit  |
| 28         | RW          | 0x0                | swap8_out<br>0: no swap<br>1: swap 8bit   |
| 27         | RW          | 0x0                | swap16_out<br>0: no swap<br>1: swap 16bit |
| 26         | RW          | 0x0                | swap32_out<br>0: no swap<br>1: swap 32bit |
| 25         | RO          | 0x0                | reserved                                  |
| 24         | RW          | 0x0                | test_irq<br>test irq                      |
| 23:20      | RW          | 0x0                | test_counter<br>test counter              |
| 19         | RW          | 0x0                | coher_test_reg<br>test register coherency |
| 18         | RW          | 0x0                | coher_test_mem<br>test memory coherency   |
| 17:0       | RW          | 0x00000            | test_len<br>test data length              |

**VEPU\_swreg\_106\_reuse**

Address: Operational Base + offset (0x01a8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------|
| 31:24      | RW          | 0x00               | pic_para_id                                                       |
| 23:16      | RW          | 0x00               | intra_pred_mode<br>H.264 intra prediction previous 4x4 mode favor |
| 15:0       | RW          | 0x0000             | frame_num<br>H.264 frame number                                   |

**VEPU\_swreg\_107\_reuse**

Address: Operational Base + offset (0x01ac)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                    |
|------------|-------------|--------------------|-------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                              |
| 29:20      | RW          | 0x000              | mv_ply_16x8_8x16<br>Penalty for using 16x8 or 8x16 MV |
| 19:10      | RW          | 0x000              | mv_ply_8x8<br>Penalty for using 8x8 MV                |
| 9:0        | RW          | 0x000              | mv_ply_8x4_4x8<br>Penalty for using 8x4 or 4x8 MV.    |

**VEPU\_swreg\_108\_reuse**

Address: Operational Base + offset (0x01b0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | intra_slice_bmp2<br>bit0 : slices64<br>bit1 : slices65<br>bit2 : slices66<br>.....<br>bit31 : slices95<br>VP8:<br>VP8 counters or probability updates start address |

**VEPU\_swreg\_109**

Address: Operational Base + offset (0x01b4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                              |
|------------|-------------|--------------------|-------------------------------------------------|
| 31:29      | RO          | 0x0                | reserved                                        |
| 28         | RW          | 0x0                | int_non<br>Field0000 Description                |
| 27:25      | RO          | 0x0                | reserved                                        |
| 24         | RW          | 0x0                | mv_sad_wren                                     |
| 23:21      | RO          | 0x0                | reserved                                        |
| 20         | RW          | 0x0                | rocon_write_dis                                 |
| 19:17      | RO          | 0x0                | reserved                                        |
| 16         | RW          | 0x0                | slice_rdyint_en<br>enable slice ready interrupt |
| 15:13      | RO          | 0x0                | reserved                                        |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                             |
|------------|-------------|--------------------|------------------------------------------------|
| 12         | RW          | 0x1                | clk_gating_en<br>default clk_gating_en =1'b1   |
| 11         | RO          | 0x0                | reserved                                       |
| 10         | RW          | 0x0                | int_timeout_en<br>enable interrupt for timeout |
| 9          | RW          | 0x0                | irq_clr                                        |
| 8          | RW          | 0x0                | irq_dis                                        |
| 7          | RO          | 0x0                | reserved                                       |
| 6          | RW          | 0x0                | irq_timeout                                    |
| 5          | RW          | 0x0                | irq_buffer_full                                |
| 4          | RW          | 0x0                | irq_bus_error                                  |
| 3          | RW          | 0x0                | fuse_int<br>Field0000 Description              |
| 2          | RW          | 0x0                | irq_slice_ready                                |
| 1          | RW          | 0x0                | irq_frame_rdy                                  |
| 0          | RW          | 0x0                | enc_irq                                        |

**VEPU swreg 110 read**

Address: Operational Base + offset (0x01b8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>        |
|------------|-------------|--------------------|---------------------------|
| 31:16      | RO          | 0x4831             | prod_id<br>Product ID     |
| 15:12      | RO          | 0x1                | major_num<br>Major number |
| 11:4       | RO          | 0x22               | minor_num<br>Minor number |
| 3:0        | RO          | 0x0                | synthesis                 |

**VEPU swreg 120 183**

Address: Operational Base + offset (0x01e0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | WO          | 0x00000000         | dmv_ply_table<br>addr range : 0x01e0~0x02dc<br>swreg120: DMV 4p/1p penalty table values<br>swreg121: DMV 4p/1p penalty table values<br>swreg122: DMV 4p/1p penalty table values<br>swreg123: DMV 4p/1p penalty table values<br>.....<br>swreg183: DMV 4p/1p penalty table values |

**5.4.9 VDPU121 Register Summary**

| <b>Name</b>         | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>                               |
|---------------------|---------------|-------------|--------------------|--------------------------------------------------|
| <u>VDPU_SWREG0</u>  | 0x0000        | W           | 0x00010100         | axi control                                      |
| <u>VDPU_SWREG1</u>  | 0x0004        | W           | 0x00000000         | color coeff register0                            |
| <u>VDPU_SWREG2</u>  | 0x0008        | W           | 0x00000000         | color coeff register1                            |
| <u>VDPU_SWREG3</u>  | 0x000c        | W           | 0x00000000         | color coeff register2                            |
| <u>VDPU_SWREG4</u>  | 0x0010        | W           | 0x00000000         | scl ctrl register0                               |
| <u>VDPU_SWREG5</u>  | 0x0014        | W           | 0x00000000         | scl ctrl register1                               |
| <u>VDPU_SWREG6</u>  | 0x0018        | W           | 0x00000000         | scl ctrl register2                               |
| <u>VDPU_SWREG7</u>  | 0x001c        | W           | 0x00000000         | Amount of pixels beyond border register0         |
| <u>VDPU_SWREG8</u>  | 0x0020        | W           | 0x00000000         | Amount of pixels beyond border register2         |
| <u>VDPU_SWREG9</u>  | 0x0024        | W           | 0x00000000         | Rmask register                                   |
| <u>VDPU_SWREG10</u> | 0x0028        | W           | 0x00000000         | Gmask register                                   |
| <u>VDPU_SWREG11</u> | 0x002c        | W           | 0x00000000         | Bmask register                                   |
| <u>VDPU_SWREG12</u> | 0x0030        | W           | 0x00000000         | PP input picture base address for Y bottom field |
| <u>VDPU_SWREG13</u> | 0x0034        | W           | 0x00000000         | PP input picture base for Ch bottom field        |
| <u>VDPU_SWREG14</u> | 0x0038        | W           | 0x00000000         | coordinate used in macroblock crop               |
| <u>VDPU_SWREG15</u> | 0x003c        | W           | 0x00000000         | range map register                               |
| <u>VDPU_SWREG16</u> | 0x0040        | W           | 0x00000000         | total num of padded for RGB                      |
| <u>VDPU_SWREG17</u> | 0x0044        | W           | 0x00000000         | hw support informan,read only                    |

| <b>Name</b>         | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>                                                                 |
|---------------------|---------------|-------------|--------------------|------------------------------------------------------------------------------------|
| <u>VDPU_SWREG18</u> | 0x0048        | W           | 0x00000000         | base address for reading post-processing input picture luminance (top field/frame) |
| <u>VDPU_SWREG19</u> | 0x004c        | W           | 0x00000000         | Base address for reading post-processing input picture Cb/Ch (topfield/frame)      |
| <u>VDPU_SWREG20</u> | 0x0050        | W           | 0x00000000         | input cr component address                                                         |
| <u>VDPU_SWREG21</u> | 0x0054        | W           | 0x00000000         | Base address for writing post-processed picture luminance/RGB                      |
| <u>VDPU_SWREG22</u> | 0x0058        | W           | 0x00000000         | Base address for writing post-processed picture Ch                                 |
| <u>VDPU_SWREG23</u> | 0x005c        | W           | 0x00000000         | Display width and PP input size extension register                                 |
| <u>VDPU_SWREG24</u> | 0x0060        | W           | 0x00000000         | alpha blending base address                                                        |
| <u>VDPU_SWREG25</u> | 0x0064        | W           | 0x00000000         | ablen of pixels scanline                                                           |
| <u>VDPU_SWREG26</u> | 0x0068        | W           | 0x00000000         | x-coordinate of mask area 1 for Horizontal start pixel                             |
| <u>VDPU_SWREG27</u> | 0x006c        | W           | 0x00000000         | y-coordinate of mask area 1 for Horizontal start pixel                             |
| <u>VDPU_SWREG28</u> | 0x0070        | W           | 0x00000000         | x-coordinate of mask area 2 for Horizontal start pixel                             |
| <u>VDPU_SWREG29</u> | 0x0074        | W           | 0x00000000         | y-coordinate of mask area 2 for Horizontal start pixel                             |
| <u>VDPU_SWREG30</u> | 0x0078        | W           | 0x00000000         | register for deinterlace ctrl                                                      |
| <u>VDPU_SWREG31</u> | 0x007c        | W           | 0x00000000         | contrast adjust threshold                                                          |
| <u>VDPU_SWREG32</u> | 0x0080        | W           | 0x00000000         | contrast adjust offset                                                             |
| <u>VDPU_SWREG33</u> | 0x0084        | W           | 0xfc874780         | Synthesis configuration register post-processor (read only)                        |

| <b>Name</b>         | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>                             |
|---------------------|---------------|-------------|--------------------|------------------------------------------------|
| <u>VDPU_SWREG34</u> | 0x0088        | W           | 0x00000000         | PP input pic size register                     |
| <u>VDPU_SWREG35</u> | 0x008c        | W           | 0x00000000         | PP output pic size register                    |
| <u>VDPU_SWREG36</u> | 0x0090        | W           | 0x00000000         | the dither mode for RGB                        |
| <u>VDPU_SWREG37</u> | 0x0094        | W           | 0x00000000         | PP input/output data format                    |
| <u>VDPU_SWREG38</u> | 0x0098        | W           | 0x00000000         | PP input/output data format                    |
| <u>VDPU_SWREG39</u> | 0x009c        | W           | 0x00000000         | the display width ctrl                         |
| <u>VDPU_SWREG40</u> | 0x00a0        | W           | 0x00000000         | Register0001 Description                       |
| <u>VDPU_SWREG41</u> | 0x00a4        | W           | 0x00000008         | enable ctrl flag                               |
| <u>VDPU_SWREG50</u> | 0x00c8        | W           | 0x00000000         | video decoder ctrl register                    |
| <u>VDPU_SWREG51</u> | 0x00cc        | W           | 0x00000000         | the stream length                              |
| <u>VDPU_SWREG52</u> | 0x00d0        | W           | 0x00000000         | error concealment case related                 |
| <u>VDPU_SWREG53</u> | 0x00d4        | W           | 0x00000000         | decoder format                                 |
| <u>VDPU_SWREG54</u> | 0x00d8        | W           | 0x00000000         | endian for input/output data                   |
| <u>VDPU_SWREG55</u> | 0x00dc        | W           | 0x00000000         | decoder int register                           |
| <u>VDPU_SWREG56</u> | 0x00e0        | W           | 0x00200101         | axi ctrl for decoder                           |
| <u>VDPU_SWREG57</u> | 0x00e4        | W           | 0x00000010         | enable flag for decoder                        |
| <u>VDPU_SWREG58</u> | 0x00e8        | W           | 0x00000000         | soft reset registerconfig addr=4E8             |
| <u>VDPU_SWREG59</u> | 0x00ec        | W           | 0x00000000         | H264, MPEG4, VC1, VP6<br>Prediction filter tap |
| <u>VDPU_SWREG60</u> | 0x00f0        | W           | 0x00000000         | additional chrominance address                 |
| <u>VDPU_SWREG61</u> | 0x00f4        | W           | 0x00000000         | standard dependent tables start address        |

| <b>Name</b>         | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|---------------------|---------------|-------------|--------------------|----------------------------------------------------------|
| <u>VDPU_SWREG62</u> | 0x00f8        | W           | 0x00000000         | Direct mode motion vector write/read start address       |
| <u>VDPU_SWREG63</u> | 0x00fc        | W           | 0x00000000         | write decoder output picture or field start address      |
| <u>VDPU_SWREG64</u> | 0x0100        | W           | 0x00000000         | rlc or vlc mode input data start addr                    |
| <u>VDPU_SWREG65</u> | 0x0104        | W           | 0x00000000         | refbufferd related                                       |
| <u>VDPU_SWREG66</u> | 0x0108        | W           | 0x67312688         | ID register                                              |
| <u>VDPU_SWREG67</u> | 0x010c        | W           | 0xc1520000         | Synthesis configuration register decoder 1(read only)    |
| <u>VDPU_SWREG68</u> | 0x0110        | W           | 0x00000000         | sum of partitions(read only)                             |
| <u>VDPU_SWREG69</u> | 0x0114        | W           | 0x00000000         | sum information (read only)                              |
| <u>VDPU_SWREG70</u> | 0x0118        | W           | 0x00000000         | sum of the decoded motion vector y-components(read only) |
| <u>VDPU_SWREG71</u> | 0x011c        | W           | 0xfb56780          | information for read only register                       |
| <u>VDPU_SWREG72</u> | 0x0120        | W           | 0x00000000         | debug0                                                   |
| <u>VDPU_SWREG73</u> | 0x0124        | W           | 0x00000000         | debug registers                                          |
| <u>VDPU_SWREG74</u> | 0x0128        | W           | 0x00000000         | MV address for h264                                      |
| <u>VDPU_SWREG75</u> | 0x012c        | W           | 0x00000000         | H.264 Intra prediction 4x4 mode start address            |
| <u>VDPU_SWREG76</u> | 0x0130        | W           | 0x00000000         | the number of reference pic0                             |
| <u>VDPU_SWREG77</u> | 0x0134        | W           | 0x00000000         | the number of reference pic1                             |
| <u>VDPU_SWREG78</u> | 0x0138        | W           | 0x00000000         | the number of reference pic2                             |
| <u>VDPU_SWREG79</u> | 0x013c        | W           | 0x00000000         | the number of reference pic3                             |
| <u>VDPU_SWREG80</u> | 0x0140        | W           | 0x00000000         | the number of reference pic4                             |

| <b>Name</b>         | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>                 |
|---------------------|---------------|-------------|--------------------|------------------------------------|
| <u>VDPU_SWREG81</u> | 0x0144        | W           | 0x00000000         | the number of reference pic5       |
| <u>VDPU_SWREG82</u> | 0x0148        | W           | 0x00000000         | the number of reference pic6       |
| <u>VDPU_SWREG83</u> | 0x014c        | W           | 0x00000000         | the number of reference pic7       |
| <u>VDPU_SWREG84</u> | 0x0150        | W           | 0x00000000         | reference frame0 address for h264  |
| <u>VDPU_SWREG85</u> | 0x0154        | W           | 0x00000000         | reference frame1 address for h264  |
| <u>VDPU_SWREG86</u> | 0x0158        | W           | 0x00000000         | reference frame2 address for h264  |
| <u>VDPU_SWREG87</u> | 0x015c        | W           | 0x00000000         | reference frame3 address for h264  |
| <u>VDPU_SWREG88</u> | 0x0160        | W           | 0x00000000         | reference frame4 address for h264  |
| <u>VDPU_SWREG89</u> | 0x0164        | W           | 0x00000000         | reference frame5 address for h264  |
| <u>VDPU_SWREG90</u> | 0x0168        | W           | 0x00000000         | reference frame6 address for h264  |
| <u>VDPU_SWREG91</u> | 0x016c        | W           | 0x00000000         | reference frame6 address for h264  |
| <u>VDPU_SWREG92</u> | 0x0170        | W           | 0x00000000         | reference frame8 address for h264  |
| <u>VDPU_SWREG93</u> | 0x0174        | W           | 0x00000000         | reference frame9 address for h264  |
| <u>VDPU_SWREG94</u> | 0x0178        | W           | 0x00000000         | reference frame10 address for h264 |
| <u>VDPU_SWREG95</u> | 0x017c        | W           | 0x00000000         | reference frame11 address for h264 |

| <b>Name</b>          | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>                         |
|----------------------|---------------|-------------|--------------------|--------------------------------------------|
| <u>VDPU_SWREG96</u>  | 0x0180        | W           | 0x00000000         | reference frame12 address for h264         |
| <u>VDPU_SWREG97</u>  | 0x0184        | W           | 0x00000000         | reference frame13 address for h264         |
| <u>VDPU_SWREG98</u>  | 0x0188        | W           | 0x00000000         | reference frame14 address for h264         |
| <u>VDPU_SWREG99</u>  | 0x018c        | W           | 0x00000000         | reference frame15 address for h264         |
| <u>VDPU_SWREG100</u> | 0x0190        | W           | 0x00000000         | initial reference picture list related0    |
| <u>VDPU_SWREG101</u> | 0x0194        | W           | 0x00000000         | initial reference picture list related1    |
| <u>VDPU_SWREG102</u> | 0x0198        | W           | 0x00000000         | initial reference picture list related2    |
| <u>VDPU_SWREG103</u> | 0x019c        | W           | 0x00000000         | initial reference picture list related3    |
| <u>VDPU_SWREG104</u> | 0x01a0        | W           | 0x00000000         | initial reference picture list related4    |
| <u>VDPU_SWREG105</u> | 0x01a4        | W           | 0x00000000         | initial reference picture list related5    |
| <u>VDPU_SWREG106</u> | 0x01a8        | W           | 0x00000000         | initial reference picture list related6    |
| <u>VDPU_SWREG107</u> | 0x01ac        | W           | 0x00000000         | long term flag for reference picture index |
| <u>VDPU_SWREG108</u> | 0x01b0        | W           | 0x00000000         | valid flag for reference picture index     |
| <u>VDPU_SWREG109</u> | 0x01b4        | W           | 0x00000000         | the stream start word for decoder          |
| <u>VDPU_SWREG110</u> | 0x01b8        | W           | 0x00000000         | h264 pic mb size                           |

| <b>Name</b>          | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>            |
|----------------------|---------------|-------------|--------------------|-------------------------------|
| <u>VDPU_SWREG111</u> | 0x01bc        | W           | 0x00000000         | h264 ctrl related             |
| <u>VDPU_SWREG112</u> | 0x01c0        | W           | 0x00000000         | current frame related         |
| <u>VDPU_SWREG113</u> | 0x01c4        | W           | 0x00000000         | reference picture related     |
| <u>VDPU_SWREG114</u> | 0x01c8        | W           | 0x00000000         | maximum reference             |
| <u>VDPU_SWREG115</u> | 0x01cc        | W           | 0x00000000         | enable flag                   |
| <u>VDPU_SWREG120</u> | 0x01e0        | W           | 0x00000000         | multi format reuse register0  |
| <u>VDPU_SWREG121</u> | 0x01e4        | W           | 0x00000000         | multi format reuse register1  |
| <u>VDPU_SWREG122</u> | 0x01e8        | W           | 0x00000000         | multi format reuse register2  |
| <u>VDPU_SWREG123</u> | 0x01ec        | W           | 0x00000000         | multi format reuse register3  |
| <u>VDPU_SWREG124</u> | 0x01f0        | W           | 0x00000000         | multi format reuse register4  |
| <u>VDPU_SWREG125</u> | 0x01f4        | W           | 0x00000000         | multi format reuse register5  |
| <u>VDPU_SWREG126</u> | 0x01f8        | W           | 0x00000000         | multi format reuse register6  |
| <u>VDPU_SWREG127</u> | 0x01fc        | W           | 0x00000000         | multi format reuse register7  |
| <u>VDPU_SWREG128</u> | 0x0200        | W           | 0x00000000         | multi format reuse register8  |
| <u>VDPU_SWREG129</u> | 0x0204        | W           | 0x00000000         | multi format reuse register9  |
| <u>VDPU_SWREG130</u> | 0x0208        | W           | 0x00000000         | multi format reuse register10 |
| <u>VDPU_SWREG131</u> | 0x020c        | W           | 0x00000000         | multi format reuse register11 |
| <u>VDPU_SWREG132</u> | 0x0210        | W           | 0x00000000         | multi format reuse register12 |
| <u>VDPU_SWREG133</u> | 0x0214        | W           | 0x00000000         | multi format reuse register13 |
| <u>VDPU_SWREG134</u> | 0x0218        | W           | 0x00000000         | multi format reuse register14 |
| <u>VDPU_SWREG135</u> | 0x021c        | W           | 0x00000000         | multi format reuse register15 |

| <b>Name</b>          | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>            |
|----------------------|---------------|-------------|--------------------|-------------------------------|
| <u>VDPU_SWREG136</u> | 0x0220        | W           | 0x00000000         | multi format reuse register16 |
| <u>VDPU_SWREG137</u> | 0x0224        | W           | 0x00000000         | multi format reuse register17 |
| <u>VDPU_SWREG138</u> | 0x0228        | W           | 0x00000000         | multi format reuse register18 |
| <u>VDPU_SWREG139</u> | 0x022c        | W           | 0x00000000         | multi format reuse register19 |
| <u>VDPU_SWREG140</u> | 0x0230        | W           | 0x00000000         | multi format reuse register20 |
| <u>VDPU_SWREG141</u> | 0x0234        | W           | 0x00000000         | multi format reuse register21 |
| <u>VDPU_SWREG142</u> | 0x0238        | W           | 0x00000000         | multi format reuse register22 |
| <u>VDPU_SWREG143</u> | 0x023c        | W           | 0x00000000         | multi format reuse register23 |
| <u>VDPU_SWREG144</u> | 0x0240        | W           | 0x00000000         | multi format reuse register24 |
| <u>VDPU_SWREG145</u> | 0x0244        | W           | 0x00000000         | multi format reuse register25 |
| <u>VDPU_SWREG146</u> | 0x0248        | W           | 0x00000000         | multi format reuse register26 |
| <u>VDPU_SWREG147</u> | 0x024c        | W           | 0x00000000         | multi format reuse register27 |
| <u>VDPU_SWREG148</u> | 0x0250        | W           | 0x00000000         | multi format reuse register28 |
| <u>VDPU_SWREG149</u> | 0x0254        | W           | 0x00000000         | multi format reuse register29 |
| <u>VDPU_SWREG150</u> | 0x0258        | W           | 0x00000000         | multi format reuse register30 |
| <u>VDPU_SWREG151</u> | 0x025c        | W           | 0x00000000         | multi format reuse register31 |
| <u>VDPU_SWREG152</u> | 0x0260        | W           | 0x00000000         | multi format reuse register32 |
| <u>VDPU_SWREG153</u> | 0x0264        | W           | 0x00000000         | multi format reuse register33 |
| <u>VDPU_SWREG154</u> | 0x0268        | W           | 0x00000000         | multi format reuse register34 |
| <u>VDPU_SWREG155</u> | 0x026c        | W           | 0x00000000         | multi format reuse register35 |
| <u>VDPU_SWREG156</u> | 0x0270        | W           | 0x00000000         | multi format reuse register36 |

| Name                                   | Offset | Size | Reset Value | Description                                        |
|----------------------------------------|--------|------|-------------|----------------------------------------------------|
| VDPU_SWREG157                          | 0x0274 | W    | 0x00000000  | multi format reuse register37                      |
| VDPU_SWREG158                          | 0x0278 | W    | 0x00000000  | multi format reuse register38                      |
| VDPU_SWREG164_PERF_LATENCY_CTRL0       | 0x0290 | W    | 0x00000000  | Axi performance latency module contrl register0    |
| VDPU_SWREG165_PERF_LATENCY_CTRL1       | 0x0294 | W    | 0x00000000  | PERF_LATENCY_CTRL1                                 |
| VDPU_SWREG166_PERF_RD_MAX_LATENCY_NUM0 | 0x0298 | W    | 0x00000000  | Read max latency number                            |
| VDPU_SWREG167_PERF_RD_LATENCY_SAMP_NUM | 0x029c | W    | 0x00000000  | The number of bigger than configed threshold value |
| VDPU_SWREG168_PERF_RD_LATENCY_ACC_SUM  | 0x02a0 | W    | 0x00000000  | Total sample number                                |
| VDPU_SWREG169_PERF_RD_AXI_TOTAL_BYTE   | 0x02a4 | W    | 0x00000000  | perf_rd_axi_total_byte                             |
| VDPU_SWREG170_PERF_WR_AXI_TOTAL_BYTE   | 0x02a8 | W    | 0x00000000  | perf_wr_axi_total_byte                             |
| VDPU_SWREG171_PERF_WORKING_CNT         | 0x02ac | W    | 0x00000000  | perf_working_cnt                                   |

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

#### 5.4.10 VDPU121 Detail Register Description

##### VDPU\_SWREG0

Address: Operational Base + offset (0x0000)

| Bit   | Attr | Reset Value | Description                                                                 |
|-------|------|-------------|-----------------------------------------------------------------------------|
| 31:24 | RO   | 0x0         | reserved                                                                    |
| 23:16 | RW   | 0x01        | sw_axi_id_wr<br>if you config 0,will modify as 1 by hw                      |
| 15:8  | RW   | 0x01        | sw_axi_id_rd<br>if you config 0,will modify as 1 by hw                      |
| 7:6   | RO   | 0x0         | reserved                                                                    |
| 5     | RW   | 0x0         | sw_scmd_off<br>on-off for AXI Single Command Multiple Data<br>0:on<br>1:off |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>               |
|------------|-------------|--------------------|----------------------------------|
| 4:0        | RW          | 0x00               | sw_max_burst_len<br>range : 1-16 |

**VDPU SWREG1**

Address: Operational Base + offset (0x0004)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                                                         |
| 29:20      | RW          | 0x000              | sw_coe_2st<br>used for red color components calculate,used together with cr pix  |
| 19:10      | RW          | 0x000              | sw_coe_1st_1<br>used for all color components calculate,used together with y pix |
| 9:0        | RW          | 0x000              | sw_coe_1st_0<br>used for all color components calculate,used together with y pix |

**VDPU SWREG2**

Address: Operational Base + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                                                          |
| 29:20      | RW          | 0x000              | sw_coe_5st<br>used for blue components calculate,used together with cb pix        |
| 19:10      | RW          | 0x000              | sw_coe_4st<br>used for green color components calculate,used together with cb pix |
| 9:0        | RW          | 0x000              | sw_coe_3st<br>used for green color components calculate,used together with cr pix |

**VDPU SWREG3**

Address: Operational Base + offset (0x000c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                                            |
| 7:0        | RW          | 0x00               | sw_coe_6st<br>used for burrightness adjust,used together with y pix |

**VDPU SWREG4**

Address: Operational Base + offset (0x0010)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                          |
|------------|-------------|--------------------|-------------------------------------------------------------|
| 31:24      | RO          | 0x0                | reserved                                                    |
| 23:22      | RW          | 0x0                | sw_scl_mode_vrt<br>0 = no scl<br>1 = up scl<br>2 = down scl |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                          |
|------------|-------------|--------------------|-------------------------------------------------------------|
| 21:20      | RW          | 0x0                | sw_scl_mode_hrz<br>0 = no scl<br>1 = up scl<br>2 = down scl |
| 19:18      | RO          | 0x0                | reserved                                                    |
| 17:0       | RW          | 0x00000            | sw_scl_fct_w<br>value = (output_width-1)/(input_width-1)    |

**VDPU\_SWREG5**

Address: Operational Base + offset (0x0014)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 31:18      | RO          | 0x0                | reserved                                                 |
| 17:0       | RW          | 0x00000            | sw_scl_fct_h<br>value = (output_width-1)/(input_width-1) |

**VDPU\_SWREG6**

Address: Operational Base + offset (0x0018)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                  |
|------------|-------------|--------------------|-----------------------------------------------------|
| 31:16      | RW          | 0x0000             | sw_scl_fct_h_inv<br>value =(inputw-1) / (outputw-1) |
| 15:0       | RW          | 0x0000             | sw_scl_fct_w_inv<br>value =(inputw-1) / (outputw-1) |

**VDPU\_SWREG7**

Address: Operational Base + offset (0x001c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                         |
|------------|-------------|--------------------|--------------------------------------------|
| 31:27      | RO          | 0x0                | reserved                                   |
| 26:16      | RW          | 0x000              | sw_pixnum_down_byd<br>Range : 0-dst_height |
| 15:11      | RO          | 0x0                | reserved                                   |
| 10:0       | RW          | 0x000              | sw_pixnum_up_byd<br>Range : 0-dst_height   |

**VDPU\_SWREG8**

Address: Operational Base + offset (0x0020)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                         |
|------------|-------------|--------------------|--------------------------------------------|
| 31:27      | RO          | 0x0                | reserved                                   |
| 26:16      | RW          | 0x000              | sw_pixnum_right_byd<br>Range : 0~dst_width |
| 15:11      | RO          | 0x0                | reserved                                   |
| 10:0       | RW          | 0x000              | sw_pixnum_left_byd<br>Range : 0~dst_width  |

**VDPU\_SWREG9**

Address: Operational Base + offset (0x0024)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                         |
|------------|-------------|--------------------|------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_mask_r<br>color R/(alpha channel) component 's bit mask |

**VDPU\_SWREG10**

Address: Operational Base + offset (0x0028)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                         |
|------------|-------------|--------------------|------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_mask_g<br>color G/(alpha channel) component 's bit mask |

**VDPU\_SWREG11**

Address: Operational Base + offset (0x002c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                         |
|------------|-------------|--------------------|------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_mask_b<br>color B/(alpha channel) component 's bit mask |

**VDPU\_SWREG12**

Address: Operational Base + offset (0x0030)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------|
| 31:2       | RW          | 0x00000000         | sw_botfld_y_st_addr<br>input bottom field pp start address for y component |
| 1:0        | RO          | 0x0                | reserved                                                                   |

**VDPU\_SWREG13**

Address: Operational Base + offset (0x0034)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------|
| 31:2       | RW          | 0x00000000         | sw_botfld_c_st_addr<br>input bottom field pp start address for c component |
| 1:0        | RO          | 0x0                | reserved                                                                   |

**VDPU\_SWREG14**

Address: Operational Base + offset (0x0038)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                                                                                                                                           |
| 29         | RW          | 0x0                | sw_mrrmb_8pix_flag<br>829PP input picture width is not 16 pixels multiple. Only 8 pixels of the most right MB of the unrotated input picture is used for PP input. |
| 28         | RW          | 0x0                | sw_mdmb_8pix_flag<br>the most down unrotated MB of input picture just 8 rows pix data                                                                              |
| 27         | RO          | 0x0                | reserved                                                                                                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------|
| 26:24      | RW          | 0x0                | sw_mbcrop_crdty_ext<br>in order to support jpeg to extend coordinate y bits |
| 23:16      | RW          | 0x00               | sw_mbcrop_crdty<br>coordinate y used in macroblock crop                     |
| 15:12      | RO          | 0x0                | reserved                                                                    |
| 11:9       | RW          | 0x0                | sw_mbcrop_crdtx_ext<br>in order to support jpeg to extend bits              |
| 8:0        | RW          | 0x000              | sw_mbcrop_crdtx<br>coordinate x used in macroblock crop                     |

**VDPU\_SWREG15**

Address: Operational Base + offset (0x003c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------|
| 31:13      | RO          | 0x0                | reserved                                                                    |
| 12:8       | RW          | 0x00               | sw_rangemap_coef_c<br>VC- 1:c range map value +9                            |
| 7:6        | RO          | 0x0                | reserved                                                                    |
| 5          | RW          | 0x0                | sw_yuv_conv_range<br>Y:<br>0:16~235<br>1:0~255<br>C:<br>0:16~240<br>1:0~255 |
| 4:0        | RW          | 0x00               | sw_rangemap_y<br>VC- 1:y range map value +9                                 |

**VDPU\_SWREG16**

Address: Operational Base + offset (0x0040)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                           |
|------------|-------------|--------------------|--------------------------------------------------------------|
| 31:21      | RO          | 0x0                | reserved                                                     |
| 20:16      | RW          | 0x00               | sw_padd_b<br>the total num of padded in front of B component |
| 15:13      | RO          | 0x0                | reserved                                                     |
| 12:8       | RW          | 0x00               | sw_padd_g<br>the total num of padded in front of G component |
| 7:5        | RO          | 0x0                | reserved                                                     |
| 4:0        | RW          | 0x00               | sw_padd_r<br>the total num of padded in front of R component |

**VDPU\_SWREG17**

Address: Operational Base + offset (0x0044)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 30         | RO          | 0x0                | pp_deinterl_en<br>0: off<br>1 : on   |
| 29         | RO          | 0x0                | pp_abled_en<br>0: off<br>1 : on      |
| 28         | RO          | 0x0                | pp_work_en<br>0 : off<br>1: on       |
| 27:4       | RO          | 0x0                | reserved                             |
| 3          | RO          | 0x0                | pp_outw_1920_en<br>1st priority used |
| 2          | RO          | 0x0                | pp_outw_1280_en<br>2st priority used |
| 1          | RO          | 0x0                | pp_outw_720_en<br>3st priority used  |
| 0          | RO          | 0x0                | pp_outw_352_en<br>4st priority used  |

**VDPU\_SWREG18**

Address: Operational Base + offset (0x0048)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------|
| 31:2       | RW          | 0x00000000         | sw_y_in_st_adr<br>The start address of topfield of the picture when data come from fields,external mode support only |
| 1:0        | RO          | 0x0                | reserved                                                                                                             |

**VDPU\_SWREG19**

Address: Operational Base + offset (0x004c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------|
| 31:2       | RW          | 0x00000000         | sw_cb_in_st_adr<br>The start address of topfield of the picture when data come from fields,external mode support only |
| 1:0        | RO          | 0x0                | reserved                                                                                                              |

**VDPU\_SWREG20**

Address: Operational Base + offset (0x0050)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------|
| 31:2       | RW          | 0x00000000         | sw_cr_in_st_adr<br>The start address of topfield of the picture when data come from fields,external mode support only |
| 1:0        | RO          | 0x0                | reserved                                                                                                              |

**VDPU\_SWREG21**

Address: Operational Base + offset (0x0054)

| Bit  | Attr | Reset Value | Description                                               |
|------|------|-------------|-----------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | sw_y_out_st_adr<br>also the start address of YUYV and RGB |

**VDPU\_SWREG22**

Address: Operational Base + offset (0x0058)

| Bit  | Attr | Reset Value | Description                             |
|------|------|-------------|-----------------------------------------|
| 31:0 | RW   | 0x00000000  | sw_c_out_st_adr<br>format is uvuvuv.... |

**VDPU\_SWREG23**

Address: Operational Base + offset (0x005c)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                               |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | sw_abled_st_adr_1st<br>1.valid when mask1 is used in alpha blending mode<br>2.Format of data the same as in PP input.<br>3.Amount of data is related to mask 1 size or ablend1_scanline informed with mask 1 size or with ablend1_scanline if ablend when crop flag valid |

**VDPU\_SWREG24**

Address: Operational Base + offset (0x0060)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                               |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | sw_abled_st_adr_2st<br>1.valid when mask2 is used in alpha blending mode<br>2.Format of data the same as in PP input.<br>3.Amount of data is related to mask 2 size or ablend1_scanline informed with mask 1 size or with ablend1_scanline if ablend when crop flag valid |

**VDPU\_SWREG25**

Address: Operational Base + offset (0x0064)

| Bit   | Attr | Reset Value | Description                                                |
|-------|------|-------------|------------------------------------------------------------|
| 31:29 | RO   | 0x0         | reserved                                                   |
| 28:16 | RW   | 0x0000      | sw_scndl_abld2<br>corresponding function should be enabled |
| 15:13 | RO   | 0x0         | reserved                                                   |
| 12:0  | RW   | 0x0000      | sw_scndl_abld1<br>corresponding function should be enabled |

**VDPU\_SWREG26**

Address: Operational Base + offset (0x0068)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------|
| 31:23      | RO          | 0x0                | reserved                                                                            |
| 22:12      | RW          | 0x000              | sw_end_coordx_ma1<br>range:sw_st_coordx_ma1~dst width                               |
| 11         | RO          | 0x0                | reserved                                                                            |
| 10:0       | RW          | 0x000              | sw_st_coordx_ma1<br>the start x-coordinate of mask area 1 of Horizontal start pixel |

**VDPU\_SWREG27**

Address: Operational Base + offset (0x006c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------|
| 31:23      | RO          | 0x0                | reserved                                                                          |
| 22:12      | RW          | 0x000              | sw_end_coordy_ma1<br>range:sw_st_coordy_ma1~dst width                             |
| 11         | RO          | 0x0                | reserved                                                                          |
| 10:0       | RW          | 0x000              | sw_st_coordy_ma1<br>the start y-coordinate of mask area 1 of Vertical start pixel |

**VDPU\_SWREG28**

Address: Operational Base + offset (0x0070)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------|
| 31:22      | RO          | 0x0                | reserved                                                                            |
| 21:11      | RW          | 0x000              | sw_end_coordx_ma2<br>range:sw_st_coordx_ma2~dst width                               |
| 10:0       | RW          | 0x000              | sw_st_coordx_ma2<br>the start x-coordinate of mask area 2 of Horizontal start pixel |

**VDPU\_SWREG29**

Address: Operational Base + offset (0x0074)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------|
| 31:22      | RO          | 0x0                | reserved                                                                          |
| 21:11      | RW          | 0x000              | sw_end_coordy_ma2<br>range:sw_st_coordy_ma2~dst width                             |
| 10:0       | RW          | 0x000              | sw_st_coordy_ma2<br>the start y-coordinate of mask area 2 of Vertical start pixel |

**VDPU\_SWREG30**

Address: Operational Base + offset (0x0078)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                           |
|------------|-------------|--------------------|--------------------------------------------------------------|
| 31         | RO          | 0x0                | reserved                                                     |
| 30:16      | RW          | 0x0000             | sw_deinterl_edge<br>Edge detect value used for deinterlacing |
| 15:14      | RO          | 0x0                | reserved                                                     |
| 13:0       | RW          | 0x0000             | sw_deinterl_thr<br>the threshold value of deinterlace        |

**VDPU SWREG31**

Address: Operational Base + offset (0x007c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                        |
|------------|-------------|--------------------|-----------------------------------------------------------|
| 31:16      | RO          | 0x0                | reserved                                                  |
| 15:8       | RW          | 0x00               | sw_cont_thr1<br>the threshold value 1 for contrast adjust |
| 7:0        | RW          | 0x00               | sw_cont_thr0<br>the threshold value 0 for contrast adjust |

**VDPU SWREG32**

Address: Operational Base + offset (0x0080)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                        |
|------------|-------------|--------------------|-----------------------------------------------------------|
| 31:26      | RO          | 0x0                | reserved                                                  |
| 25:16      | RW          | 0x000              | sw_cont_offset1<br>the offset value 1 for contrast adjust |
| 15:10      | RO          | 0x0                | reserved                                                  |
| 9:0        | RW          | 0x000              | sw_cont_offset0<br>the offset value 0 for contrast adjust |

**VDPU SWREG33**

Address: Operational Base + offset (0x0084)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RO          | 0x1                | abld_crop_flag<br>0: unsupport crop, the exact image of the area being alpha blended should exist in the external memory<br>1: support crop, one picture in external memory which come from blended area can be cropped |
| 30         | RO          | 0x1                | accut_out_exist_flag<br>PIP:<br>0 : use 8 pixels (width) or 2 pixels (height) steps to adjust Scaling and masks<br>1 : use 1 pixel for RGB and 2 pixels for subsampled chroma formats to adjust Scaling and masks       |
| 29         | RO          | 0x1                | tile_exist_flag<br>0 : no exist<br>1 : exist                                                                                                                                                                            |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| 28         | RO          | 0x1                | dither_exist_flag<br>0 : no exist<br>1 : exist                                                                                              |
| 27:26      | RO          | 0x3                | scl_perf_sel<br>0 : without scaling<br>1 : low performance scaling<br>2 : high performance scaling<br>3 : high and fast performance scaling |
| 25         | RO          | 0x0                | deinterl_exist_flag<br>0 : no exist<br>1 : exist                                                                                            |
| 24         | RO          | 0x0                | abld_exist_flag<br>0 : no exist<br>1 : exist                                                                                                |
| 23         | RO          | 0x1                | pp_in_buf_sel<br>0 : output buffering is 1 MB<br>1 : output buffering is 4 MB                                                               |
| 22:19      | RO          | 0x0                | reserved                                                                                                                                    |
| 18         | RO          | 0x1                | pp_endian_mode<br>0 : Endian mode supported except RGB<br>1 : Endian mode supported for all format                                          |
| 17         | RO          | 0x1                | pp_out_buf_sel<br>0 : output buffering is 1 unit<br>1 : output buffering is 4 unit                                                          |
| 16         | RO          | 0x1                | ppd_exist_flag<br>0 : no exist<br>1 : exist                                                                                                 |
| 15:14      | RO          | 0x1                | pp_tile_in_mode<br>0 : unsupport<br>1 : 8x4 tile be used                                                                                    |
| 13:11      | RO          | 0x0                | reserved                                                                                                                                    |
| 10:0       | RO          | 0x780              | ppd_max_outw<br>the max pixels width allow for pp output                                                                                    |

**VDPU SWREG34**

Address: Operational Base + offset (0x0088)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:29      | RW          | 0x0                | sw_pp_inh_ext<br>in order to support jpeg                                                                                                          |
| 28:21      | RW          | 0x00               | sw_pp_inh<br>the picture height of PP input with in macro blocks which can be cropped from a bigger picture when in the condition of external mode |
| 20:12      | RW          | 0x000              | sw_org_inw_ext<br>the orginal width of pp input pic in MBS                                                                                         |
| 11:9       | RW          | 0x0                | sw_pp_inw_ext<br>in order to support jpeg                                                                                                          |
| 8:0        | RW          | 0x000              | sw_pp_inw<br>the picture width of PP input with in macro blocks which can be cropped from a bigger picture when in the condition of external mode  |

**VDPU SWREG35**

Address: Operational Base + offset (0x008c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                    |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                                                                                                                                                              |
| 27         | RW          | 0x0                | sw_pp_outh_ext<br>the extension height of pp output                                                                                                                                                   |
| 26:16      | RW          | 0x000              | sw_pp_outh<br>(output width = 2*n (n=1,2,.....)    output width<br>=(configuration Pixel Accurate PP output configuration)*n )<br>&&<br>( pp output width < 1920    pp output width< 3*(sw_pp_inh-8)) |
| 15:12      | RO          | 0x0                | reserved                                                                                                                                                                                              |
| 11         | RW          | 0x0                | sw_pp_outw_ext<br>the extension width of pp output                                                                                                                                                    |
| 10:0       | RW          | 0x000              | sw_pp_outw<br>(output width = 8*n (n=1,2,.....)    output width<br>=(configuration Pixel Accurate PP output configuration)*n )<br>&&<br>( pp output width < 1920    pp output width< 3*(sw_pp_inw-8)) |

**VDPU SWREG36**

Address: Operational Base + offset (0x0090)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6       | RO          | 0x0                | reserved                                                                                                                                             |
| 5:4        | RW          | 0x0                | sw_dither_mode_b<br>0 : no use dithering<br>1 : 4-bits dither matrix be used<br>2 : 5-bits dither matrix be used<br>3 : 6-bits dither matrix be used |
| 3:2        | RW          | 0x0                | sw_dither_mode_g<br>0 : no use dithering<br>1 : 4-bits dither matrix be used<br>2 : 5-bits dither matrix be used<br>3 : 6-bits dither matrix be used |
| 1:0        | RW          | 0x0                | sw_dither_mode_r<br>0 : no use dithering<br>1 : 4-bits dither matrix be used<br>2 : 5-bits dither matrix be used<br>3 : 6-bits dither matrix be used |

**VDPU\_SWREG37**

Address: Operational Base + offset (0x0094)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:27      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                               |
| 26:24      | RW          | 0x0                | sw_pp_in_data_strc<br>0 : Top field<br>1 : Bottom field<br>2 : Interlaced field<br>3 : Interlaced frame<br>4 : Ripped top field<br>5 : Ripped bottom field<br>if value=0/1/2,then should read every line from the base address,if value=3/4/5,then should read every second line from the base address |
| 23:20      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                               |
| 19         | RW          | 0x0                | sw_pp_out_crbf_en<br>0 : Y0CbY0Cr / CbY0CrY0<br>1 : Y0CrY0Cb / CrY0CbY0                                                                                                                                                                                                                                |
| 18         | RW          | 0x0                | sw_pp_in_crbf_en<br>yuv422:<br>0 : Y0CbY0Cr / CbY0CrY0<br>1 : Y0CrY0Cb / CrY0CbY0<br>yuv420 semiplanar chrominance:<br>0 : CbCrCbCr<br>1:CrCbCrCb                                                                                                                                                      |
| 17         | RW          | 0x0                | sw_pp_out_yuv_order<br>0 : Y0CbY0Cr / Y0CrY0Cb<br>1 : CbY0CrY0 / CrY0CbY0                                                                                                                                                                                                                              |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16         | RW          | 0x0                | sw_pp_in_yuv_order<br>0 : Y0CbY0Cr / Y0CrY0Cb<br>1 : CbY0CrY0 / CrY0CbY0                                                                                                                                                      |
| 15:12      | RO          | 0x0                | reserved                                                                                                                                                                                                                      |
| 11         | RW          | 0x0                | sw_pp_out_wordsp<br>it will be used in 64 bit environment<br>0 : no swapping<br>1 : swapping high and low 32bit data                                                                                                          |
| 10         | RW          | 0x0                | sw_pp_out_hfwordsp<br>0: no swap<br>1: swap<br>also be used as change pixel orders for 16 bit RGB, support all output format<br>require pp_endian_mode=1                                                                      |
| 9          | RW          | 0x0                | sw_pp_abld1_in_wordsp<br>for Alpha blend source 1<br>0 : no swapping<br>1 : swapping high and low 32bit data                                                                                                                  |
| 8          | RW          | 0x0                | sw_pp_in_wordsp<br>it will be used in 64 bit environment<br>0 : no swapping<br>1 : swapping high and low 32bit data                                                                                                           |
| 7:5        | RO          | 0x0                | reserved                                                                                                                                                                                                                      |
| 4          | RW          | 0x0                | sw_rgb_pix_bits<br>0: every word have only one rga pixel<br>1: every word have two rga pixel                                                                                                                                  |
| 3          | RW          | 0x0                | sw_pp_out_endian<br>for all yuv output endian mode or any data when pp_endian_mode=1<br>0 : big endian<br>1 : little endian<br>if pp_endian_mode=0:<br>16 bit RGB: this bit used as pixel swapping bit<br>32 bit RGB: no used |
| 2          | RW          | 0x0                | sw_pp_abld2_in_endian<br>0: same with sw_pp_in_endian<br>1: same with sw_pp_abld1_in_endian<br>'0' = Use PP in endian/swap definitions (sw_pp_in_endian, sw_pp_in_swap)<br>'1' = Use Ablend source 1 endian/swap definitions  |
| 1          | RW          | 0x0                | sw_pp_abld1_in_endian<br>0 : big endian (0-1-2-3)<br>1 : little endian (3-2-1-0 )                                                                                                                                             |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0          | RW          | 0x0                | <p>sw_pp_in_endian<br/>this bit will no longer be used when PP is running pipelined with the decoder</p> <p>0 : big endian (0-1-2-3)<br/>1 : little endian (3-2-1-0 )</p> |

**VDPU\_SWREG38**

Address: Operational Base + offset (0x0098)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:22      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                      |
| 21:20      | RW          | 0x0                | <p>sw_pp_in_tilmod<br/>only support yuv420 input data, can be as pipeline or external mode</p> <p>0 : Tiled mode not be activated<br/>1 : 8x4 sized tiles be used<br/>2,3 : reserved</p>                                                                                                                                      |
| 19         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                      |
| 18:16      | RW          | 0x0                | <p>sw_pp_in_fmt_ecp<br/>be activated when sw_pp_in_fmt = 3'b111</p> <p>0 : YCbCr 4:4:4<br/>1 : YCbCr 4:1:1</p>                                                                                                                                                                                                                |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                      |
| 13:11      | RW          | 0x0                | <p>sw_pp_out_fmt</p> <p>0 : RGB<br/>1 : YCbCr 4:2:0 ; planar (Not supported)<br/>2 : YCbCr 4:2:2 ; planar (Not supported)<br/>3 : YUYV 4:2:2 ; interleaved<br/>4 : YCbCr 4:4:4 ; planar (Not supported)<br/>5 : YCh 4:2:0 ; chrominance interleaved<br/>6 : YCh 4:2:2 ; (Not supported)<br/>7 : YCh 4:4:4 (Not supported)</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10:8       | RW          | 0x0                | <p>sw_pp_in_fmt<br/>           0 : YUYV 4:2:2 ; interleaved and it only supported in external mode<br/>           1 : YCbCr 4:2:0 ; the format of Semi-planar in linear raster-scan<br/>           2 : YCbCr 4:2:0 ; planar and it only supported in external mode<br/>           3 : YCbCr 4:0:0 ; it only supported in pipelined mode<br/>           4 : YCbCr 4:2:2 ; Semi-planar and it only supported only in pipelined mode<br/>           5 : YCbCr 4:2:0 ; Semi-planar in tiled format and it only supported in external mode<br/>           6 : YCbCr 4:4:0 ; Semi-planar and it only supported for jpeg in pipelined mode<br/>           7 : same as sw_pp_in_fmt_ecp</p> |
| 7:3        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 2:0        | RW          | 0x0                | <p>sw_rot_mode<br/>           0 : rotation disabled<br/>           1 : rotate + 90<br/>           2 : rotate -90<br/>           3 : horizontal flip (mirror)<br/>           4 : vertical flip<br/>           5 : rotate 180</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

**VDPU SWREG39**

Address: Operational Base + offset (0x009c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>               |
|------------|-------------|--------------------|----------------------------------|
| 31:12      | RO          | 0x0                | reserved                         |
| 11:0       | RW          | 0x000              | sw_display_w<br>Max support 1920 |

**VDPU SWREG40**

Address: Operational Base + offset (0x00a0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------|
| 31:4       | RO          | 0x0                | reserved                                                                   |
| 3          | RW          | 0x0                | sw_pp_bus_sts<br>the Interrupt status bit for tell sw bus have some error  |
| 2          | RW          | 0x0                | sw_pp_rdy_sts<br>the Interrupt status bit for tell sw processed a picture  |
| 1          | RW          | 0x0                | sw_pp_irq_dis<br>1 : use polling to see the interrupt<br>0 : use sw_pp_irq |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------|
| 0          | RW          | 0x0                | sw_pp_irq<br>after sw query this interrupt, shoud write 0 to reset.<br>this bit will no used in pipeline mode |

**VDPU\_SWREG41**

Address: Operational Base + offset (0x00a4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:29      | RO          | 0x0                | reserved                                                                                                                                                                  |
| 28         | RW          | 0x0                | sw_pp_ahb_hlock_en<br>the service is locked to pp as long as it needs the bus                                                                                             |
| 27         | RW          | 0x0                | sw_rightwd_cross_en<br>0 : disable,<br>1 : enable                                                                                                                         |
| 26         | RW          | 0x0                | sw_leftsd_cross_en<br>0 : disable,<br>1 : enable                                                                                                                          |
| 25         | RW          | 0x0                | sw_downwd_cross_en<br>0 : disable,<br>1 : enable                                                                                                                          |
| 24         | RW          | 0x0                | sw_upwd_cross_en<br>0 : disable,<br>1 : enable                                                                                                                            |
| 23         | RW          | 0x0                | sw_mask2_abld_en<br>alpha blending for the output picture , only be supported when data format is RGB/YUYV422<br>Alpha blending read data from alpha blend 2 base address |
| 22         | RW          | 0x0                | sw_mask1_abld_en<br>alpha blending for the output picture , only be supported when data format is RGB/YUYV422<br>Alpha blending read data from alpha blend 1 base address |
| 21         | RW          | 0x0                | sw_mask2_en<br>0 : disable,<br>1 : enable                                                                                                                                 |
| 20         | RW          | 0x0                | sw_mask1_en<br>0 : disable,<br>1 : enable                                                                                                                                 |
| 19:17      | RO          | 0x0                | reserved                                                                                                                                                                  |
| 16         | RW          | 0x0                | sw_pp_discd_en<br>the burst length will be fix after sw_pp_discd_en=1, and extra read data will auto be discarded by HW                                                   |
| 15:12      | RO          | 0x0                | reserved                                                                                                                                                                  |
| 11         | RW          | 0x0                | sw_pp_out_tiled_en<br>only used in YCbYCr format .<br>Tile size : 4x4 pixels.                                                                                             |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10         | RW          | 0x0                | sw_pp_fdscl_en<br>0 : disable<br>1 : enabled. it will improve the performance but will decrease the quality of the pic                                                                                                                                                                                                   |
| 9          | RW          | 0x0                | sw_rangemap_c_en<br>the enable flag for C component Range map                                                                                                                                                                                                                                                            |
| 8          | RW          | 0x0                | sw_rangemap_y_en<br>VC1: used as range expansion enable                                                                                                                                                                                                                                                                  |
| 7:5        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                 |
| 4          | RW          | 0x0                | sw_pp_pipl_en<br>0 : disable, external mode<br>1 : enable, pipeline mode, Post-processing pipeline with decoder                                                                                                                                                                                                          |
| 3          | RW          | 0x1                | sw_pp_clkgate_en<br>pp auto clock gating:<br>default is 1<br>0 : don't auto gating<br>1 : auto gating<br>PP dynamic clock gating enable:<br>1 = Clock is gated from PP structures that are not used<br>0 = Clock is running for all PP structures<br>Note: Clock gating value can be changed only when PP is not enabled |
| 2          | RW          | 0x0                | sw_deint_en<br>the input data should be interlaced format                                                                                                                                                                                                                                                                |
| 1          | RW          | 0x0                | sw_deint_bld_en<br>on-off Blend for deinterlacing                                                                                                                                                                                                                                                                        |
| 0          | RW          | 0x0                | sw_pp_dec_st<br>after config other register, write 1 to start post-processing operation, and hw will reset to 0 after it decoded a picture should be under External mode.                                                                                                                                                |

**VDPU SWREG50**

Address: Operational Base + offset (0x00c8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                                                               |
| 29:25      | RW          | 0x00               | sw_refbuf_pid<br>The used reference picture ID for reference buffer usage              |
| 24:13      | RW          | 0x000              | sw_refbuf_thrd<br>Used shut down buffer                                                |
| 12         | RW          | 0x0                | sw_dec_tiled_lsb<br>0 : Tiled mode disable<br>1 : Tiled mode enabled for 8x4 tile size |
| 11         | RW          | 0x0                | sw_adv_pref_dis<br>disable for Advanced PREFETCH mode                                  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10         | RW          | 0x0                | sw_dec_ascmd0_dis<br>the disable for AXI Single Command Multiple Data0                                                                                                                                            |
| 9          | RW          | 0x0                | sw_skip_sel<br>AVS format:<br>0 : skip mbs use special MB type<br>1 : avs skip mbs have the same skip run syntax element as h264                                                                                  |
| 8          | RW          | 0x0                | sw_dblk_flt_dis<br>1: disable<br>0: enable                                                                                                                                                                        |
| 7          | RW          | 0x0                | sw_dec_fixed_quant<br>h.264:<br>this bit is for the enable of multi view coding<br>other format(VC1)<br>0: it can be different inside pic for Quantization parameter<br>1: it is fixed for Quantization parameter |
| 6:1        | RW          | 0x00               | sw_adtion_latency<br>Can be used to slow down 8*sw_dec_latency cycles of IDLE between services, so if sw_dec_latency =0, that is no latency                                                                       |
| 0          | RW          | 0x0                | sw_dec_tiled_msb<br>0 : Tiled mode disable<br>1 : Tiled mode enabled for 8x4 tile size                                                                                                                            |

**VDPU\_SWREG51**

Address: Operational Base + offset (0x00cc)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 30:25      | RW          | 0x00               | sw_qp_init_val<br>the qp(quantization parameter)'s Initial value                                                                                                                                                                                                                                                                                                                                                                             |
| 24         | RW          | 0x0                | sw_strm_len_ext<br>The extension bit of sw_strm_len                                                                                                                                                                                                                                                                                                                                                                                          |
| 23:0       | RW          | 0x000000           | sw_strm_len<br>if the buffer size be given small than it required, hw will give an interrupt, and then you should config again, and the stream start address should be config also.<br>VC1:<br>one picture/slice of the picture's should be included in the input buffer<br>H264/H263/MPEG*:<br>one slice of the picture's should be included in the input buffer<br>JPEG:<br>256bytes or one picture should be included in the input buffer |

**VDPU\_SWREG52**

Address: Operational Base + offset (0x00d0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                               |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------|
| 31         | RO          | 0x0                | reserved                                                                                         |
| 30:17      | RW          | 0x0000             | sw_adv_pref_thrd<br>when current MB num > this threshold value,then advanced mode will be closed |
| 16:8       | RW          | 0x000              | sw_xdim_mbst<br>it may be used in error concealment case                                         |
| 7:0        | RW          | 0x00               | sw_ydim_mbst<br>it may be used in error concealment case                                         |

**VDPU\_SWREG53**

Address: Operational Base + offset (0x00d4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4       | RO          | 0x0                | reserved                                                                                                                                                        |
| 3:0        | RW          | 0x0                | sw_dec_fmt_sel<br>0 : H.264,<br>1 : MPEG-4,<br>2 : H.263,<br>3 : JPEG,<br>4 : VC-1,<br>5 : MPEG-2,<br>6 : MPEG-1,<br>9 : VP7,<br>11 : AVS,<br>others : reserved |

**VDPU\_SWREG54**

Address: Operational Base + offset (0x00d8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------|
| 31:6       | RO          | 0x0                | reserved                                                                                                               |
| 5          | RW          | 0x0                | sw_dec_strendian_e<br>0 : Big endian (0-1-2-3 order)<br>1 : Little endian (3-2-1-0 order)                              |
| 4          | RW          | 0x0                | sw_dec_strm_wordsp<br>it will be used in 64 bit environment<br>0 : no swapping<br>1 : swapping high and low 32bit data |
| 3          | RW          | 0x0                | sw_dec_out_wordsp<br>it will be used in 64 bit environment<br>0 : no swapping<br>1 : swapping high and low 32bit data  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                        |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2          | RW          | 0x0                | sw_dec_in_wordsp<br>it will be used in 64 bit environment<br>0 : no swapping<br>1 : swapping high and low 32bit data<br>note : it no used for stream data |
| 1          | RW          | 0x0                | sw_dec_out_endian<br>Decoder output endian mode:<br>0 : Big endian (0-1-2-3 order)<br>1 : Little endian (3-2-1-0 order)                                   |
| 0          | RW          | 0x0                | sw_dec_in_endian<br>0 : Big endian (0-1-2-3 order)<br>1 : Little endian (3-2-1-0 order)<br>note : it no used for stream data                              |

**VDPU\_SWREG55**

Address: Operational Base + offset (0x00dc)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:14      | RO          | 0x0                | reserved                                                                                                                                                           |
| 13         | RW          | 0x0                | sw_timeout_det_sts<br>AXI in IDLE status too long                                                                                                                  |
| 12         | RW          | 0x0                | sw_error_det_sts<br>Interrupt status bit input stream error. When high, an error is found in input data stream decoding. HW will self reset.<br>(1,2,3,6,48,55,57) |
| 11         | RO          | 0x0                | reserved                                                                                                                                                           |
| 10         | RO          | 0x0                | reserved                                                                                                                                                           |
| 9          | RW          | 0x0                | sw_slice_det_sts<br>the Interrupt status bit for tell us slice be decoded                                                                                          |
| 8          | RW          | 0x0                | sw_aso_det_sts<br>ASO:Arbitrary Slice Ordering                                                                                                                     |
| 7          | RO          | 0x0                | reserved                                                                                                                                                           |
| 6          | RW          | 0x0                | sw_buf_emt_sts<br>the Interrupt status bit for tell input buffer empty                                                                                             |
| 5          | RW          | 0x0                | sw_pp_bus_sts<br>the Interrupt status bit for tell sw bus have some error                                                                                          |
| 4          | RW          | 0x0                | sw_dec_rdy_sts<br>the Interrupt status bit for tell sw processed a picture                                                                                         |
| 3:2        | RO          | 0x0                | reserved                                                                                                                                                           |
| 1          | RW          | 0x0                | sw_dec_irq_dis<br>1 : use polling to see the interrupt<br>0 : use sw_pp_irq                                                                                        |
| 0          | RW          | 0x0                | sw_dec_irq<br>after sw query this interrupt, shoud write 0 to reset.                                                                                               |

**VDPU\_SWREG56**

Address: Operational Base + offset (0x00e0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:24      | RO          | 0x0                | reserved                                                                                                                          |
| 23         | RW          | 0x0                | sw_axi_sel<br>0: auto sel for encoder or decoder<br>1: sel decoder (only used in the middle decoder frame to set bus_dec_en to 0) |
| 22         | RW          | 0x0                | sw_dec_data_discd_en<br>the fixed burst length will be used ,and the more read datas will be auto discarded by hw                 |
| 21         | RW          | 0x1                | sw_bus_pos_sel<br>0:serial<br>1:parallel                                                                                          |
| 20:16      | RW          | 0x00               | sw_dec_max_burlen<br>range : 1-16                                                                                                 |
| 15:8       | RW          | 0x01               | sw_dec_axi_id_wr<br>if you config 0,will modify as 1 by hw                                                                        |
| 7:0        | RW          | 0x01               | sw_dec_axi_id_rd<br>if you config 0/5,will modify as 1 by hw                                                                      |

**VDPU\_SWREG57**

Address: Operational Base + offset (0x00e4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------|
| 31         | RW          | 0x0                | sw_dec_timeout_mode<br>when 1'b0 , timeout cycle is 181'b1<br>when 1'b1, timeout cycle is 221'b1                          |
| 30         | RO          | 0x0                | reserved                                                                                                                  |
| 29         | RW          | 0x0                | sw_cache_en<br>1'b1: cache enable<br>1'b0: cache disable<br>when sw_cache_en is 1'b1, sw_pref_sigchan should also be 1'b1 |
| 28         | RW          | 0x0                | sw_pref_sigchan<br>1'b1: prefetch single channel enable                                                                   |
| 27         | RW          | 0x0                | sw_intra dbl3t<br>In chroma dc intra prediction, when this bit is enable, there will 3 cycle enhance for every block      |
| 26         | RW          | 0x0                | sw_intra dblspeed<br>Intra double speed enable                                                                            |
| 25         | RW          | 0x0                | sw_inter dblspeed<br>Inter double speed enable                                                                            |
| 24:23      | RO          | 0x0                | reserved                                                                                                                  |
| 22         | RW          | 0x0                | sw_st_code_exist<br>0 : not exist<br>1 : exist                                                                            |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 21         | RW          | 0x0                | sw_addit_ch_fmt_wen<br>tiled mode should be disable,when this bit be used<br>decoder writes chrominance: group of 8 pixels of Cb then<br>corresponding 8 pixels of Cr<br>Data is written to sw_dec_ch8pix_st_adr. |
| 20         | RW          | 0x0                | sw_rlc_mode_en<br>0:decoder data come from bit stream(VLC mode),side<br>information (bitplane data in VC-1)<br>1:decoder data come from RLC input data,only h.264 and MPEG4<br>sp be valid                        |
| 19         | RO          | 0x0                | reserved                                                                                                                                                                                                          |
| 18         | RW          | 0x0                | sw_prog_jpeg_en<br>0 : baseline JPEG<br>1 : progressive JPEG                                                                                                                                                      |
| 17         | RW          | 0x0                | sw_curpic_code_sel<br>0 : progressive<br>1 : interlaced                                                                                                                                                           |
| 16         | RW          | 0x0                | sw_curpic_stru_sel<br>0 : frame structure, (that is MBAFF structured picture is<br>interlaced)<br>1 : field structure                                                                                             |
| 15         | RW          | 0x0                | sw_pic_type_sel1<br>0:desided by sw_pic_type_sel0<br>1: picture type is BI/D/B<br>note:<br>BI is for vc1<br>D is for mpeg1<br>B is for h264                                                                       |
| 14         | RW          | 0x0                | sw_pic_type_sel0<br>should need sw_pic_type_sel1=0<br>0: Intra type (I)<br>1:Inter type (P)                                                                                                                       |
| 13         | RW          | 0x0                | sw_pic_decfield_sel<br>0 : bottom field<br>1 : top field                                                                                                                                                          |
| 12         | RW          | 0x0                | sw_fwd_refpic_mode_sel<br>used for forward reference picture:<br>0 : progressive<br>1 : interlaced<br>the backward reference picture is the same as current picture                                               |
| 11         | RO          | 0x0                | reserved                                                                                                                                                                                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10         | RW          | 0x0                | sw_dmmv_wr_en<br>0:disable<br>1:enable<br>this bit used in MPEG2 is for the purpose error concealment case.<br>this bit used in h264 is for the purpose write DPB case with the corresponding reference picture.<br>this bit used in other decoder format is for the purpose writing to external memory starting from mv start address |
| 9          | RW          | 0x0                | sw_reftop_en<br>sw_dec_fmt_sel =VC-1 and sw_ref_frm = 0 ,<br>0 = bottom field<br>1 = top field                                                                                                                                                                                                                                         |
| 8          | RW          | 0x0                | sw_first_reftop_en<br>0 : FWD reference bottom field<br>1 : FWD reference top field                                                                                                                                                                                                                                                    |
| 7          | RW          | 0x0                | sw_sequ_mbuff_en<br>0:disable<br>1:enable                                                                                                                                                                                                                                                                                              |
| 6          | RW          | 0x0                | sw_rd_cnt_tab_en<br>read data from memory used<br>0:disable<br>1:enable (hw will read pic order counts)                                                                                                                                                                                                                                |
| 5          | RW          | 0x0                | sw_timeout_sts_en<br>0:disable<br>1:enable (if hw can be working status too long,you will get an timeout interrupt)                                                                                                                                                                                                                    |
| 4          | RW          | 0x1                | sw_dec_clkgate_en<br>default hw will reset to 1<br>0:disable<br>1:enable                                                                                                                                                                                                                                                               |
| 3          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                               |
| 2          | RW          | 0x0                | sw_dec_wr_extmem_dis<br>0 : enable<br>1:disable(no write to external memory)                                                                                                                                                                                                                                                           |
| 1          | RW          | 0x0                | sw_refpic_buf2_en<br>0:disable<br>1:enable (should : pic size > QVGA)                                                                                                                                                                                                                                                                  |
| 0          | RW          | 0x0                | sw_dec_st_work<br>hw will auto reset this be after a frame be decoded no matter it right or have some error                                                                                                                                                                                                                            |

**VDPU SWREG58**

Address: Operational Base + offset (0x00e8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                           |
|------------|-------------|--------------------|------------------------------------------------------------------------------|
| 31:1       | RO          | 0x0                | reserved                                                                     |
| 0          | W1<br>C     | 0x0                | sw_soft_RST<br>write 1 to reset, and it will auto reset to 0 after one cycle |

**VDPU\_SWREG59**

Address: Operational Base + offset (0x00ec)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                |
|------------|-------------|--------------------|-----------------------------------|
| 31:22      | RW          | 0x000              | sw_pflt_set0_tap0<br>0, tap 0     |
| 21:12      | RW          | 0x000              | sw_pflt_set0_tap1<br>set 0, tap 1 |
| 11:2       | RW          | 0x000              | sw_pflt_set0_tap2<br>set 0, tap 2 |
| 1:0        | RO          | 0x0                | reserved                          |

**VDPU\_SWREG60**

Address: Operational Base + offset (0x00f0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------|
| 31:2       | RW          | 0x00000000         | sw_addit_ch_st_adr<br>The usage is enabled by sw_addit_ch_fmt_wen |
| 1:0        | RO          | 0x0                | reserved                                                          |

**VDPU\_SWREG61**

Address: Operational Base + offset (0x00f4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                           |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------|
| 31:2       | RW          | 0x00000000         | sw_qtable_st_adr<br>JPEG : AC, DC, QP tables<br>MPEG4/2 : QP table<br>H.264 : various tables<br>VP7 : stream decoding tables |
| 1:0        | RO          | 0x0                | reserved                                                                                                                     |

**VDPU\_SWREG62**

Address: Operational Base + offset (0x00f8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2       | RW          | 0x00000000         | <p>sw_dmmv_st_adr<br/>H264:<br/>Direct mode motion vector write/read start address</p> <p>Progressive JPEG:<br/>the start address for ACDC coefficient read/write</p> <p>If current round is for DC components :<br/>this start address is pointing to luminance</p> <p>AC component rounds:<br/>this start address is used for current type</p> |
| 1:0        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                         |

**VDPU\_SWREG63**

Address: Operational Base + offset (0x00fc)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2       | RW          | 0x00000000         | <p>sw_dec_out_st_adr<br/>video:<br/>write decoder output picture or field start address</p> <p>JPEG snapshot:<br/>wirte decoder output luminance picture start address</p> |
| 1:0        | RO          | 0x0                | reserved                                                                                                                                                                   |

**VDPU\_SWREG64**

Address: Operational Base + offset (0x0100)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2       | RW          | 0x00000000         | <p>sw_rlc_vlc_st_adr<br/>RLC mode:<br/>RLC data start address</p> <p>VLC mode:<br/>Stream start address<br/>HW return value of last_byte_address by this register to tell where stream has been read when you get some abnormality interrupt, may be used for debug</p> <p>VP7:<br/>DCT stream for MB rows 0,2n start address</p> |
| 1:0        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                          |

**VDPU\_SWREG65**

Address: Operational Base + offset (0x0104)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                               |
|------------|-------------|--------------------|--------------------------------------------------|
| 31         | RW          | 0x0                | <p>sw_refbu_e<br/>0 : disable<br/>1 : enable</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 30:19      | RW          | 0x000              | sw_refbu_thr_level<br>Reference buffer disable threshold value (cache miss amount). Used to buffer shut down (if more misses than allowed)                                  |
| 18:14      | RW          | 0x00               | sw_refbuf_picid                                                                                                                                                             |
| 13         | RW          | 0x0                | sw_refbuf_idcal_e<br>If given threshold level is reached by any picture_id after first MB row,<br>that picture_id is used for reference buffer fill for rest of the picture |
| 12         | RW          | 0x0                | sw_refbuf_fildpar_mod_e<br>the mode enable for Field parity mode enable.<br>0 : the result field of the evaluation be used<br>1 : the parity mode field be used             |
| 11:9       | RO          | 0x0                | reserved                                                                                                                                                                    |
| 8:0        | RW          | 0x000              | sw_refbuf_y_offset<br>if hw should compensate the global motion of the video for better buffer hit rate will use this coordinate                                            |

**VDPU\_SWREG66**

Address: Operational Base + offset (0x0108)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                         |
|------------|-------------|--------------------|--------------------------------------------|
| 31:16      | RO          | 0x6731             | prod_id<br>product number                  |
| 15:12      | RO          | 0x2                | major_num<br>major_num                     |
| 11:4       | RO          | 0x68               | minor_num<br>minor_num                     |
| 3          | RO          | 0x1                | ascii_id_en<br>enable for ASCII product ID |
| 2:0        | RO          | 0x0                | build_ver<br>build_ver                     |

**VDPU\_SWREG67**

Address: Operational Base + offset (0x010c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                           |
|------------|-------------|--------------------|------------------------------------------------------------------------------|
| 31         | RO          | 0x1                | jpeg_allow_flag<br>16Mpixel~67Mpixel be sampled and supported by 411 and 444 |
| 30         | RO          | 0x1                | refbuf_allow_flag<br>0:no support<br>1:support                               |
| 29         | RO          | 0x0                | reserved                                                                     |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                               |
|------------|-------------|--------------------|------------------------------------------------------------------|
| 28         | RO          | 0x0                | refbuf2_allow_flag<br>refbuffer2 support                         |
| 27:26      | RO          | 0x0                | reserved                                                         |
| 25         | RO          | 0x0                | rom_imp_type<br>0: from actual ROM units<br>1: from RTL          |
| 24         | RO          | 0x1                | vp7_allow_flag<br>vp7 support                                    |
| 23         | RO          | 0x0                | reserved                                                         |
| 22         | RO          | 0x1                | avs_allow_flag<br>avs support                                    |
| 21:20      | RO          | 0x1                | mvc_allow_flag<br>mvc support                                    |
| 19         | RO          | 0x0                | reserved                                                         |
| 18:17      | RO          | 0x1                | tile_mode_sel<br>0: no support<br>1: 8x4 support<br>2,3: no used |
| 16:0       | RO          | 0x0                | reserved                                                         |

**VDPU\_SWREG68**

Address: Operational Base + offset (0x0110)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                |
|------------|-------------|--------------------|---------------------------------------------------|
| 31:16      | RO          | 0x0000             | sw_refbuf_sum_top<br>sum of the top partitions    |
| 15:0       | RO          | 0x0000             | sw_refbuf_sum_bot<br>sum of the bottom partitions |

**VDPU\_SWREG69**

Address: Operational Base + offset (0x0114)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | sw_refbuf_sum_hit<br>sum of the refbufferd hits of the picture                |
| 15:0       | RO          | 0x0000             | sw_luma_sum_intra<br>sum of the luminance 8x8 intra partitons of the picture. |

**VDPU\_SWREG70**

Address: Operational Base + offset (0x0118)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                               |
|------------|-------------|--------------------|------------------------------------------------------------------|
| 31:22      | RO          | 0x0                | reserved                                                         |
| 21:0       | RO          | 0x0000000          | sw_ycomp_mv_sum<br>sum of the decoded motion vector y-components |

**VDPU\_SWREG71**

Address: Operational Base + offset (0x011c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RO          | 0x1                | dec_mpeg2_allow<br>0: no support<br>1: support                                                                                                                            |
| 30:29      | RO          | 0x3                | dec_vc1_allow<br>0 :not supported<br>1 :simple profile be supported<br>2 :main profile be supported<br>3 :advanced profile be supported                                   |
| 28         | RO          | 0x1                | dec_jpeg_allow<br>0: no support<br>1: support                                                                                                                             |
| 27:26      | RO          | 0x2                | dec_mpeg4_allow<br>0 :not supported<br>1 :simple profile be supported<br>2 :advanced simple profile be supported                                                          |
| 25:24      | RO          | 0x3                | dec_h264_allow<br>0: no support<br>1: baseline profile be supported<br>2: high profile be supported                                                                       |
| 23         | RO          | 0x0                | reserved                                                                                                                                                                  |
| 22         | RO          | 0x0                | dec_prog_jpeg_allow<br>0: no support<br>1: support                                                                                                                        |
| 21         | RO          | 0x1                | outbuf_sel<br>0 : 1MB buffer be used<br>1 : 4MB buffer be used                                                                                                            |
| 20         | RO          | 0x1                | refbuf_exist<br>0 : not supported<br>1 : support                                                                                                                          |
| 19:16      | RO          | 0x5                | dec_std_bus<br>0 : error<br>1 : AHB master, AHB slave<br>2 : OCP master, OCP slave<br>3 : AXI master, AXI slave<br>4 : AXI master, APB slave<br>5 : AXI master, AHB slave |
| 15:14      | RO          | 0x1                | rtl_lan_sel<br>0: no used<br>1:vhdl<br>2:verilog                                                                                                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------|
| 13:12      | RO          | 0x2                | bus_w<br>0 : error<br>1 : word bus<br>2 : double word bus<br>3 : quadruple word bus |
| 11         | RO          | 0x0                | reserved                                                                            |
| 10:0       | RO          | 0x780              | sw_dec_max_allow_w<br>the max width can be decoder                                  |

**VDPU\_SWREG72**

Address: Operational Base + offset (0x0120)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------|
| 31         | RO          | 0x0                | reserved                                                          |
| 30:24      | RO          | 0x00               | debug_service<br>this value[6:0]=service_wr[2:0], service_rd[3:0] |
| 23:0       | RO          | 0x0                | reserved                                                          |

**VDPU\_SWREG73**

Address: Operational Base + offset (0x0124)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                             |
|------------|-------------|--------------------|------------------------------------------------|
| 31         | RO          | 0x0                | reserved                                       |
| 30         | RO          | 0x0                | debug_mv_req<br>mvst_mv_req signal value       |
| 29         | RO          | 0x0                | debug_rlc_req<br>prtr_res_y_req signal value   |
| 28         | RO          | 0x0                | debug_res_y_req<br>prtr_res_y_req signal value |
| 27         | RO          | 0x0                | debug_res_c_req<br>debug_res_c_req             |
| 26         | RO          | 0x0                | debug_strm_da_e<br>debug_strm_da_e             |
| 25         | RO          | 0x0                | debug_frm_rdy<br>debug_frm_rdy                 |
| 24         | RO          | 0x0                | debug_flt_req<br>debug_flt_req                 |
| 23         | RO          | 0x0                | debug_ref0_req<br>debug_ref0_req               |
| 22         | RO          | 0x0                | debug_ref1_req<br>debug_ref1_req               |
| 21         | RO          | 0x0                | reserved                                       |
| 20:0       | RO          | 0x000000           | debug_mb_cnt<br>debug_mb_cnt                   |

**VDPU\_SWREG74**

Address: Operational Base + offset (0x0128)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2       | RW          | 0x00000000         | <p>h264_diff_mv_st_adr<br/>Differential motion vector base address used for h264 only<br/>it also reuse used as:</p> <ul style="list-style-type: none"> <li>[29:25] : 9st forward picid of initial reference pic list</li> <li>[24:20] : 8st forward picid of initial reference pic list</li> <li>[19:15] : 7st forward picid of initial reference pic list</li> <li>[14:10] : 6st forward picid of initial reference pic list</li> <li>[9:5] : 5st forward picid of initial reference pic list</li> <li>[4:0] : 4st forward picid of initial reference pic list</li> </ul> |
| 1:0        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

**VDPU\_SWREG75**

Address: Operational Base + offset (0x012c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2       | RW          | 0x00000000         | <p>h264_pred4x4_st_adr<br/>also be used as:</p> <ul style="list-style-type: none"> <li>[29:25] : 15st forward picid of initial reference pic list</li> <li>[24:20] : 14st forward picid of initial reference pic list</li> <li>[19:15] : 13st forward picid of initial reference pic list</li> <li>[14:10] : 12st forward picid of initial reference pic list</li> <li>[9:5] : 11st forward picid of initial reference pic list</li> <li>[4:0] : 10st forward picid of initial reference pic list</li> </ul> |
| 1:0        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

**VDPU\_SWREG76**

Address: Operational Base + offset (0x0130)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                      |
|------------|-------------|--------------------|---------------------------------------------------------|
| 31:16      | RW          | 0x0000             | h264_num_ref_idx1<br>the number of reference pic index1 |
| 15:0       | RW          | 0x0000             | h264_num_ref_idx0<br>the number of reference pic index0 |

**VDPU\_SWREG77**

Address: Operational Base + offset (0x0134)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                      |
|------------|-------------|--------------------|---------------------------------------------------------|
| 31:16      | RW          | 0x0000             | h264_num_ref_idx3<br>the number of reference pic index3 |
| 15:0       | RW          | 0x0000             | h264_num_ref_idx2<br>the number of reference pic index2 |

**VDPU\_SWREG78**

Address: Operational Base + offset (0x0138)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                      |
|------------|-------------|--------------------|---------------------------------------------------------|
| 31:16      | RW          | 0x0000             | h264_num_ref_idx5<br>the number of reference pic index5 |
| 15:0       | RW          | 0x0000             | h264_num_ref_idx4<br>the number of reference pic index4 |

**VDPU SWREG79**

Address: Operational Base + offset (0x013c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                      |
|------------|-------------|--------------------|---------------------------------------------------------|
| 31:16      | RW          | 0x0000             | h264_num_ref_idx7<br>the number of reference pic index7 |
| 15:0       | RW          | 0x0000             | h264_num_ref_idx6<br>the number of reference pic index6 |

**VDPU SWREG80**

Address: Operational Base + offset (0x0140)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                      |
|------------|-------------|--------------------|---------------------------------------------------------|
| 31:16      | RW          | 0x0000             | h264_num_ref_idx9<br>the number of reference pic index9 |
| 15:0       | RW          | 0x0000             | h264_num_ref_idx8<br>the number of reference pic index8 |

**VDPU SWREG81**

Address: Operational Base + offset (0x0144)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                        |
|------------|-------------|--------------------|-----------------------------------------------------------|
| 31:16      | RW          | 0x0000             | h264_num_ref_idx11<br>the number of reference pic index11 |
| 15:0       | RW          | 0x0000             | h264_num_ref_idx10<br>the number of reference pic index10 |

**VDPU SWREG82**

Address: Operational Base + offset (0x0148)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                        |
|------------|-------------|--------------------|-----------------------------------------------------------|
| 31:16      | RW          | 0x0000             | h264_num_ref_idx13<br>the number of reference pic index13 |
| 15:0       | RW          | 0x0000             | h264_num_ref_idx12<br>the number of reference pic index12 |

**VDPU SWREG83**

Address: Operational Base + offset (0x014c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                        |
|------------|-------------|--------------------|-----------------------------------------------------------|
| 31:16      | RW          | 0x0000             | h264_num_ref_idx15<br>the number of reference pic index15 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                        |
|------------|-------------|--------------------|-----------------------------------------------------------|
| 15:0       | RW          | 0x0000             | h264_num_ref_idx14<br>the number of reference pic index14 |

**VDPU SWREG84**

Address: Operational Base + offset (0x0150)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------|
| 31:2       | RW          | 0x00000000         | h264_ref0_st_addr<br>the start address of reference frame0                        |
| 1          | RW          | 0x0                | h264_ref0_field_en<br>0 : frame<br>1 : field                                      |
| 0          | RW          | 0x0                | h264_ref0_closer_sel<br>0 : bottom field be selected<br>1 : top field be selected |

**VDPU SWREG85**

Address: Operational Base + offset (0x0154)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------|
| 31:2       | RW          | 0x00000000         | h264_ref1_st_addr<br>the start address of reference frame1                        |
| 1          | RW          | 0x0                | h264_ref1_field_en<br>0 : frame<br>1 : field                                      |
| 0          | RW          | 0x0                | h264_ref1_closer_sel<br>0 : bottom field be selected<br>1 : top field be selected |

**VDPU SWREG86**

Address: Operational Base + offset (0x0158)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------|
| 31:2       | RW          | 0x00000000         | h264_ref2_st_addr<br>the start address of reference frame2                        |
| 1          | RW          | 0x0                | h264_ref2_field_en<br>0 : frame<br>1 : field                                      |
| 0          | RW          | 0x0                | h264_ref2_closer_sel<br>0 : bottom field be selected<br>1 : top field be selected |

**VDPU SWREG87**

Address: Operational Base + offset (0x015c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------|
| 31:2       | RW          | 0x00000000         | h264_ref3_st_addr<br>the start address of reference frame3                        |
| 1          | RW          | 0x0                | h264_ref3_field_en<br>0 : frame<br>1 : field                                      |
| 0          | RW          | 0x0                | h264_ref3_closer_sel<br>0 : bottom field be selected<br>1 : top field be selected |

**VDPU\_SWREG88**

Address: Operational Base + offset (0x0160)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------|
| 31:2       | RW          | 0x00000000         | h264_ref4_st_addr<br>the start address of reference frame4                        |
| 1          | RW          | 0x0                | h264_ref4_field_en<br>0 : frame<br>1 : field                                      |
| 0          | RW          | 0x0                | h264_ref4_closer_sel<br>0 : bottom field be selected<br>1 : top field be selected |

**VDPU\_SWREG89**

Address: Operational Base + offset (0x0164)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------|
| 31:2       | RW          | 0x00000000         | h264_ref5_st_addr<br>the start address of reference frame5                        |
| 1          | RW          | 0x0                | h264_ref5_field_en<br>0 : frame<br>1 : field                                      |
| 0          | RW          | 0x0                | h264_ref5_closer_sel<br>0 : bottom field be selected<br>1 : top field be selected |

**VDPU\_SWREG90**

Address: Operational Base + offset (0x0168)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------|
| 31:2       | RW          | 0x00000000         | h264_ref6_st_addr<br>the start address of reference frame6                        |
| 1          | RW          | 0x0                | h264_ref6_field_en<br>0 : frame<br>1 : field                                      |
| 0          | RW          | 0x0                | h264_ref6_closer_sel<br>0 : bottom field be selected<br>1 : top field be selected |

**VDPU\_SWREG91**

Address: Operational Base + offset (0x016c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------|
| 31:2       | RW          | 0x00000000         | h264_ref7_st_addr<br>the start address of reference frame7                        |
| 1          | RW          | 0x0                | h264_ref7_field_en<br>0 : frame<br>1 : field                                      |
| 0          | RW          | 0x0                | h264_ref7_closer_sel<br>0 : bottom field be selected<br>1 : top field be selected |

**VDPU\_SWREG92**

Address: Operational Base + offset (0x0170)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------|
| 31:2       | RW          | 0x00000000         | h264_ref8_st_addr<br>the start address of reference frame8                        |
| 1          | RW          | 0x0                | h264_ref8_field_en<br>0 : frame<br>1 : field                                      |
| 0          | RW          | 0x0                | h264_ref8_closer_sel<br>0 : bottom field be selected<br>1 : top field be selected |

**VDPU\_SWREG93**

Address: Operational Base + offset (0x0174)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------|
| 31:2       | RW          | 0x00000000         | h264_ref9_st_addr<br>the start address of reference frame9                        |
| 1          | RW          | 0x0                | h264_ref9_field_en<br>0 : frame<br>1 : field                                      |
| 0          | RW          | 0x0                | h264_ref9_closer_sel<br>0 : bottom field be selected<br>1 : top field be selected |

**VDPU\_SWREG94**

Address: Operational Base + offset (0x0178)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                           |
|------------|-------------|--------------------|--------------------------------------------------------------|
| 31:2       | RW          | 0x00000000         | h264_ref10_st_addr<br>the start address of reference frame10 |
| 1          | RW          | 0x0                | h264_ref10_field_en<br>0 : frame<br>1 : field                |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------|
| 0          | RW          | 0x0                | h264_ref10_closer_sel<br>0 : bottom field be selected<br>1 : top field be selected |

**VDPU\_SWREG95**

Address: Operational Base + offset (0x017c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------|
| 31:2       | RW          | 0x00000000         | h264_ref11_st_addr<br>the start address of reference frame11                       |
| 1          | RW          | 0x0                | h264_ref11_field_en<br>0 : frame<br>1 : field                                      |
| 0          | RW          | 0x0                | h264_ref11_closer_sel<br>0 : bottom field be selected<br>1 : top field be selected |

**VDPU\_SWREG96**

Address: Operational Base + offset (0x0180)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------|
| 31:2       | RW          | 0x00000000         | h264_ref12_st_addr<br>the start address of reference frame12                       |
| 1          | RW          | 0x0                | h264_ref12_field_en<br>0 : frame<br>1 : field                                      |
| 0          | RW          | 0x0                | h264_ref12_closer_sel<br>0 : bottom field be selected<br>1 : top field be selected |

**VDPU\_SWREG97**

Address: Operational Base + offset (0x0184)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------|
| 31:2       | RW          | 0x00000000         | h264_ref13_st_addr<br>the start address of reference frame13                       |
| 1          | RW          | 0x0                | h264_ref13_field_en<br>0 : frame<br>1 : field                                      |
| 0          | RW          | 0x0                | h264_ref13_closer_sel<br>0 : bottom field be selected<br>1 : top field be selected |

**VDPU\_SWREG98**

Address: Operational Base + offset (0x0188)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------|
| 31:2       | RW          | 0x00000000         | h264_ref14_st_addr<br>the start address of reference frame14                       |
| 1          | RW          | 0x0                | h264_ref14_field_en<br>0 : frame<br>1 : field                                      |
| 0          | RW          | 0x0                | h264_ref14_closer_sel<br>0 : bottom field be selected<br>1 : top field be selected |

**VDPU SWREG99**

Address: Operational Base + offset (0x018c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------|
| 31:2       | RW          | 0x00000000         | h264_ref15_st_addr<br>the start address of reference frame15                       |
| 1          | RW          | 0x0                | h264_ref15_field_en<br>0 : frame<br>1 : field                                      |
| 0          | RW          | 0x0                | h264_ref15_closer_sel<br>0 : bottom field be selected<br>1 : top field be selected |

**VDPU SWREG100**

Address: Operational Base + offset (0x0190)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                     |
|------------|-------------|--------------------|----------------------------------------|
| 31:30      | RO          | 0x0                | reserved                               |
| 29:25      | RW          | 0x00               | h264_init_reflist_df5<br>used for h264 |
| 24:20      | RW          | 0x00               | h264_init_reflist_df4<br>used for h264 |
| 19:15      | RW          | 0x00               | h264_init_reflist_df3<br>used for h264 |
| 14:10      | RW          | 0x00               | h264_init_reflist_df2<br>used for h264 |
| 9:5        | RW          | 0x00               | h264_init_reflist_df1<br>used for h264 |
| 4:0        | RW          | 0x00               | h264_init_reflist_df0<br>used for h264 |

**VDPU SWREG101**

Address: Operational Base + offset (0x0194)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                      |
|------------|-------------|--------------------|-----------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                |
| 29:25      | RW          | 0x00               | h264_init_reflist_df11<br>used for h264 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                      |
|------------|-------------|--------------------|-----------------------------------------|
| 24:20      | RW          | 0x00               | h264_init_reflist_df10<br>used for h264 |
| 19:15      | RW          | 0x00               | h264_init_reflist_df9<br>used for h264  |
| 14:10      | RW          | 0x00               | h264_init_reflist_df8<br>used for h264  |
| 9:5        | RW          | 0x00               | h264_init_reflist_df7<br>used for h264  |
| 4:0        | RW          | 0x00               | h264_init_reflist_df6<br>used for h264  |

**VDPU SWREG102**

Address: Operational Base + offset (0x0198)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                      |
|------------|-------------|--------------------|-----------------------------------------|
| 31:20      | RO          | 0x0                | reserved                                |
| 19:15      | RW          | 0x00               | h264_init_reflist_df15<br>used for h264 |
| 14:10      | RW          | 0x00               | h264_init_reflist_df14<br>used for h264 |
| 9:5        | RW          | 0x00               | h264_init_reflist_df13<br>used for h264 |
| 4:0        | RW          | 0x00               | h264_init_reflist_df12<br>used for h264 |

**VDPU SWREG103**

Address: Operational Base + offset (0x019c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                     |
|------------|-------------|--------------------|----------------------------------------|
| 31:30      | RO          | 0x0                | reserved                               |
| 29:25      | RW          | 0x00               | h264_init_reflist_db5<br>used for h264 |
| 24:20      | RW          | 0x00               | h264_init_reflist_db4<br>used for h264 |
| 19:15      | RW          | 0x00               | h264_init_reflist_db3<br>used for h264 |
| 14:10      | RW          | 0x00               | h264_init_reflist_db2<br>used for h264 |
| 9:5        | RW          | 0x00               | h264_init_reflist_db1<br>used for h264 |
| 4:0        | RW          | 0x00               | h264_init_reflist_db0<br>used for h264 |

**VDPU SWREG104**

Address: Operational Base + offset (0x01a0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                      |
|------------|-------------|--------------------|-----------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                |
| 29:25      | RW          | 0x00               | h264_init_reflist_db11<br>used for h264 |
| 24:20      | RW          | 0x00               | h264_init_reflist_db10<br>used for h264 |
| 19:15      | RW          | 0x00               | h264_init_reflist_db9<br>used for h264  |
| 14:10      | RW          | 0x00               | h264_init_reflist_db8<br>used for h264  |
| 9:5        | RW          | 0x00               | h264_init_reflist_db7<br>used for h264  |
| 4:0        | RW          | 0x00               | h264_init_reflist_db6<br>used for h264  |

**VDPU SWREG105**

Address: Operational Base + offset (0x01a4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                      |
|------------|-------------|--------------------|-----------------------------------------|
| 31:20      | RO          | 0x0                | reserved                                |
| 19:15      | RW          | 0x00               | h264_init_reflist_db15<br>used for h264 |
| 14:10      | RW          | 0x00               | h264_init_reflist_db14<br>used for h264 |
| 9:5        | RW          | 0x00               | h264_init_reflist_db13<br>used for h264 |
| 4:0        | RW          | 0x00               | h264_init_reflist_db12<br>used for h264 |

**VDPU SWREG106**

Address: Operational Base + offset (0x01a8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------|
| 31:20      | RO          | 0x0                | reserved                                                                      |
| 19:15      | RW          | 0x00               | h264_init_reflist_pf3<br>Initial reference picture list for P forward picid 3 |
| 14:10      | RW          | 0x00               | h264_init_reflist_pf2<br>Initial reference picture list for P forward picid 2 |
| 9:5        | RW          | 0x00               | h264_init_reflist_pf1<br>Initial reference picture list for P forward picid 1 |
| 4:0        | RW          | 0x00               | h264_init_reflist_pf0<br>used in 264                                          |

**VDPU SWREG107**

Address: Operational Base + offset (0x01ac)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | h264_refpic_term_flag<br>long term flag for reference picture index |

**VDPU\_SWREG108**

Address: Operational Base + offset (0x01b0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                               |
|------------|-------------|--------------------|------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | h264_refpic_valid_flag<br>valid flag for reference picture index |

**VDPU\_SWREG109**

Address: Operational Base + offset (0x01b4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 31:6       | RO          | 0x0                | reserved                                                 |
| 5:0        | RW          | 0x00               | h264_strm_start_bit<br>associates with sw_rlc_vlc_st_adr |

**VDPU\_SWREG110**

Address: Operational Base + offset (0x01b8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------|
| 31:27      | RO          | 0x0                | reserved                                                                                             |
| 26:22      | RW          | 0x00               | h264_flt_offset_cr_qp<br>filter offset of cr qp                                                      |
| 21:17      | RW          | 0x00               | h264_flt_offset_cb_qp<br>filter offset of cb qp                                                      |
| 16:9       | RW          | 0x00               | h264_pic_mb_h<br>value =((pixel height+15)/16).<br>used for frame or single field size being decoded |
| 8:0        | RW          | 0x000              | h264_pic_mb_w<br>value = ((pixel width + 15) /16)                                                    |

**VDPU\_SWREG111**

Address: Operational Base + offset (0x01bc)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------|
| 31:18      | RO          | 0x0                | reserved                                                                                           |
| 17:16      | RW          | 0x0                | h264_wp_bslice_sel<br>0 : default wp be used<br>1 : explicit wp be used<br>2 : implicit wp be used |
| 15:5       | RO          | 0x0                | reserved                                                                                           |
| 4:0        | RW          | 0x00               | h264_max_refnum<br>this value is for decoded picture buffer                                        |

**VDPU\_SWREG112**

Address: Operational Base + offset (0x01c0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RW          | 0x0                | h264_dblk_ctrl_flag<br>to indicates if the slice header will have the deblocking filter's extra variables controlling characteristics |
| 30         | RW          | 0x0                | h264_rpcp_flag<br>to specifies whether redundant picture count syntax elements                                                        |
| 29:21      | RO          | 0x0                | reserved                                                                                                                              |
| 20:16      | RW          | 0x00               | h264_curfrm_len<br>H.264: Bit length of frame_num in data stream                                                                      |
| 15:0       | RW          | 0x0000             | h264_curfrm_num<br>it may be use for reference picture reordering and identify short-term reference frames                            |

**VDPU SWREG113**

Address: Operational Base + offset (0x01c4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                        |
|------------|-------------|--------------------|-----------------------------------------------------------|
| 31:27      | RO          | 0x0                | reserved                                                  |
| 26:16      | RW          | 0x000              | h264_mk_len<br>use for decoded reference picture          |
| 15:0       | RW          | 0x0000             | h264_idrp_id<br>instantaneous decoding refresh picture id |

**VDPU SWREG114**

Address: Operational Base + offset (0x01c8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------|
| 31:24      | RW          | 0x00               | h264_pps_id<br>it identifies the slice header will have the id of picture parameter set |
| 23:19      | RW          | 0x00               | h264_max_refidx1<br>it will be used in decoding inter predicted macro blocks            |
| 18:14      | RW          | 0x00               | h264_max_refidx0<br>it will be used in decoding inter predicted macro blocks            |
| 13:8       | RO          | 0x0                | reserved                                                                                |
| 7:0        | RW          | 0x00               | h264_pocf_len<br>the length of picture order count field in stream                      |

**VDPU SWREG115**

Address: Operational Base + offset (0x01cc)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------|
| 31:9       | RO          | 0x0                | reserved                                                                           |
| 8          | RW          | 0x0                | h264_idr_pic_flag<br>instantaneous decoding refresh picture flag                   |
| 7          | RW          | 0x0                | h264_dlmv_method_en<br>with B_skip, B_Direct_16x16 and B_direct_8x8_inference_flag |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| 6          | RW          | 0x0                | h264_monochr_en<br>sampling format ,<br>0 : 4:2:0<br>1 : 4:0:0                                                                               |
| 5          | RW          | 0x0                | h264_cabac_en<br>enable for cabac                                                                                                            |
| 4          | RW          | 0x0                | h264_pslice_wp_en<br>enable flag of Weighted prediction for P slices                                                                         |
| 3          | RW          | 0x0                | h264_nimb_intra_en<br>0 : neighbouring inter macroblocks are used in intra prediction process<br>1 : neighbouring intra macroblocks are used |
| 2          | RW          | 0x0                | h264_trnff_flag_en_8x8<br>8x8 transform flag enable for stream decoding                                                                      |
| 1          | RW          | 0x0                | h264_scl_matrix_en<br>0 : normal transform<br>1 : use scaling matrix for transform                                                           |
| 0          | RW          | 0x0                | h264_fieldpic_flag_exist<br>Flag for streamd that field_pic_flag exists in stream                                                            |

**VDPU SWREG120**

Address: Operational Base + offset (0x01e0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | mfr_reg0<br>MPEG4/JPEG/VC-1/MPEG2/VP7/VP:<br>[31:2]<br>RLC mode: Base address for RLC data<br>VLC mode: Stream start address<br>VP7:<br>[31:2]<br>This base address is used as sw_dct_strm0_base including DCT stream for MB rows 0,2n |

**VDPU\_SWREG121**

Address: Operational Base + offset (0x01e4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | <p>mfr_reg1</p> <p>vc-1:</p> <ul style="list-style-type: none"> <li>[31] : bitplane mode enable for corresponding element0</li> <li>[30] : bitplane mode enable for corresponding element1</li> <li>[29] : bitplane mode enable for corresponding element2</li> <li>[28:24] : alemative PQUANT.</li> <li>[23:20] : weather dq_profile will be set to picture edges</li> <li>[19] : TTMB or TTFRM sel</li> <li>[18:14] : qpindex value</li> <li>[12] : enable for bilinear motion compensation ena</li> <li>[11] : enable for iform quantizer e</li> <li>[10] : enable for HALFQP</li> <li>[9:8] : frame level transform type sel</li> <li>[7] : the 2st byte of the stream emulation byte</li> <li>[6] : enable for antization parameter change inside frame</li> <li>[5] : enable for VC-1 advanced profile</li> </ul> <p>JPEG:</p> <ul style="list-style-type: none"> <li>[26:0] : progressive JPEG</li> </ul> <p>MPEG2 :</p> <ul style="list-style-type: none"> <li>[12] : enable for bilinear motion compensation</li> <li>VP7:</li> <li>[31:26] : DCT stream partition index 1 of start bit</li> <li>[25:20] : DCT stream partition index 2 of start bit</li> <li>[13] : rominance motion vector resolution for VP7/8</li> <li>[12] : enable for bilinear motion compensation</li> <li>[11:9] : 0st count for DC prediction mach</li> <li>[8:6] : 1st count for DC prediction mach</li> </ul> |

**VDPU\_SWREG122**

Address: Operational Base + offset (0x01e8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | <p>mfr_reg2</p> <p>MPEG4:</p> <ul style="list-style-type: none"> <li>[31:26] : Exact bit of stream start word</li> <li>[25] : enable for sync markers</li> <li>[24] : enable for Type 1 quantization</li> <li>[23:19] : the offset of Qp filter</li> <li>[18:14] : the offset of Qp filter for cr</li> <li>[0] : filed_pic_flag exists in stream</li> </ul> <p>JPEG :</p> <ul style="list-style-type: none"> <li>[31:26] : Exact bit of stream start word</li> <li>[25] : enable for sync markers</li> <li>[12:11] : total of Quantization tables</li> <li>[10:8] : the sampling format for input pic</li> <li>[7] : JPEG width</li> <li>[6] : weather current strem buffer contain the end of a JPEG image</li> <li>[5:0] : vlc table</li> </ul> <p>VC-1 :</p> <ul style="list-style-type: none"> <li>[31:26] : Exact bit of stream start word</li> <li>[25] : enable for sync markers</li> <li>[24] : Quantisation profile</li> <li>[23] : each mb take on quantization step size or not</li> <li>[22] : range reduced</li> <li>[20] : chrominance interpolation accuracy information</li> <li>[17:13] : select tables which be used to dec</li> <li>[12:10] : select mode syntax element table</li> <li>[9:7] : select mv table</li> <li>[6:4] : select CPBCY table</li> <li>[3:0] : block pattern table select</li> </ul> |

**VDPU\_SWREG123**

Address: Operational Base + offset (0x01ec)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | <p>mfr_reg3</p> <p>JPEG:</p> <ul style="list-style-type: none"> <li>[15:0] : start marker frequency.</li> </ul> <p>vc-1:</p> <ul style="list-style-type: none"> <li>[31:24] : B picture scl factor</li> <li>[23:19] : FWD direction reference distance</li> <li>[18:14] : BWD direction reference distance</li> </ul> <p>VP7/VP :</p> <ul style="list-style-type: none"> <li>[31:16] : value 0 for initial dc predictor</li> <li>[15:0] : value 1 for initial dc predictor</li> </ul> |

**VDPU\_SWREG124**

Address: Operational Base + offset (0x01f0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | mfr_reg4<br>MPEG4:<br>[31:2] : MB ctrl start address<br>VC-1:<br>[24] : enable for 0st intensity compensation<br>[23:16] : iscale value<br>[15:0] : ishift value<br>VP7/VP :<br>[27:24] : coefficient partitions number<br>[23:0] : total of CTRL stream data |

**VDPU\_SWREG125**

Address: Operational Base + offset (0x01f4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | mfr_reg5<br>JPEG:<br>[31:2] : Cb ACDC coeff start address<br>VP7/vp:<br>[31:22] : prediction filter with set 5 and tap 1<br>[21:12] : prediction filter with set 5 and tap 2<br>[11:2] : prediction filter with set 5 and tap 3 |

**VDPU\_SWREG126**

Address: Operational Base + offset (0x01f8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | mfr_reg6<br>JPEG:<br>[31:2] : Cr ACDC coeff start address<br>VP7/vp:<br>[31:22] : prediction filter with set 6 and tap 0<br>[21:12] : prediction filter with set 6 and tap 1<br>[11:2] : prediction filter with set 6 and tap 2 |

**VDPU\_SWREG127**

Address: Operational Base + offset (0x01fc)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                             |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | mfr_reg7<br>VP7/vp:<br>[31:22] : prediction filter with set 6 and tap 3<br>[21:12] : prediction filter with set 7 and tap 0<br>[11:2] : prediction filter with set 7 and tap 1 |

**VDPU\_SWREG128**

Address: Operational Base + offset (0x0200)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | mfr_reg8<br>VP7/VP:<br>[31:22] : prediction filter with set 7 and tap 2<br>[21:12] : prediction filter with set 7 and tap 3<br>[11:10] : extra prediction filter with set 2 and tap -1<br>[9:8] : extra prediction filter with set 2 and tap 4<br>[7:6] : extra prediction filter with set 4 and tap -1<br>[5:4] : extra prediction filter with set 4 and tap 4<br>[3:2] : extra prediction filter with set 6 and tap -1<br>[1:0] : extra prediction filter with set 6 and tap 4 |

**VDPU\_SWREG129**

Address: Operational Base + offset (0x0204)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b> |
|------------|-------------|--------------------|--------------------|
| 31:0       | RW          | 0x00000000         | mfr_reg9           |

**VDPU\_SWREG130**

Address: Operational Base + offset (0x0208)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | mfr_reg10<br>VP7:<br>[21:11] : QP0 for VP7<br>[10:0] : QP1 for VP7 |

**VDPU\_SWREG131**

Address: Operational Base + offset (0x020c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | mfr_reg11<br>MPEG4/H263/VC-1/VP7:<br>[31:2] : reference pic0 start address<br>JPEG:<br>[31:2] : the ch decoder output start address |

**VDPU\_SWREG132**

Address: Operational Base + offset (0x0210)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | mfr_reg12<br>VP7:<br>[31] : type of loop filter<br>[30:28] : sharpness of loop filter<br>[27:21] : MB type0 adjustment of filter level<br>[20:14] : MB type1 adjustment of filter level<br>[13:7] : MB type2 adjustment of filter level<br>[6:0] : MB type3 adjustment of filter level |

**VDPU\_SWREG133**

Address: Operational Base + offset (0x0214)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | mfr_reg13<br>VP7:<br>[27:21] : reference frame type0 adjustment of filter level<br>[20:14] : reference frame type1 adjustment of filter level<br>[13:7] : reference frame type2 adjustment of filter level<br>[6:0] : reference frame type3 adjustment of filter level |

**VDPU\_SWREG134**

Address: Operational Base + offset (0x0218)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | mfr_reg14<br>MPEG4/vc1/MEPG2:<br>[31:2] : reference pic2 start address<br>JPEG:<br>[30:24] : code words of length 6<br>[21:16] : code words of length 5<br>[15:11] : code words of length 4<br>[10:7] : code words of length 3<br>[5:3] : code words of length 2<br>[1:0] : code words of length 1 |

**VDPU\_SWREG135**

Address: Operational Base + offset (0x021c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | <p>mfr_reg15</p> <p>MPEG4/vc1/MEPG2:</p> <ul style="list-style-type: none"> <li>[31:2] : reference pic3 start address</li> </ul> <p>JPEG:</p> <ul style="list-style-type: none"> <li>[30:24] : code words of length 10</li> <li>[23:16] : code words of length 9</li> <li>[15:8] : code words of length 8</li> <li>[7:0] : code words of length 7</li> </ul> |

**VDPU\_SWREG136**

Address: Operational Base + offset (0x0220)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | <p>mfr_reg16</p> <p>VP7</p> <ul style="list-style-type: none"> <li>[31:2] : golden reference pic start address(PIC_ID 4)</li> <li>[0] : golden reference pic siggn bias(VP7/VP8)</li> </ul> <p>VC-1:</p> <ul style="list-style-type: none"> <li>[31:16] : length of picture header</li> <li>[13] : 1/4 MV/MB sel</li> <li>[11] : enable for ref pic range reduce</li> <li>[10:9] : max different mv length</li> <li>[7:6] : select range for mv</li> <li>[5] : enable for overlap smoothing</li> <li>[4:3] : MB overlap smoothing method</li> </ul> <p>MPEG4/MPEG2:</p> <ul style="list-style-type: none"> <li>[19] : alternalte scan flag</li> <li>[18:15] : HRZ AXI's bit amount for representing FWD MV</li> <li>[14:11] : VRZ AXI's bit amount for representing FWD MV</li> <li>[10:7] : HRZ AXI's bit amount for representing BWD MV</li> <li>[6:3] : VRZ AXI's bit amount for representing BWD MV</li> <li>[2] : FWD MV Y resolution</li> <li>[1] : the ctrl bit for rounding(MPEG4),BWD MV Y resolution(MPEG2)</li> <li>[0] : pic type of previous anchor(MPEG4)</li> </ul> <p>JPEG:</p> <ul style="list-style-type: none"> <li>[30:24] : code words of length 14</li> <li>[23:16] : code words of length 13</li> <li>[15:8] : code words of length 12</li> <li>[7:0] : code words of length 11</li> </ul> |

**VDPU\_SWREG137**

Address: Operational Base + offset (0x0224)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | <p>mfr_reg17</p> <p>MPEG4:</p> <ul style="list-style-type: none"> <li>[26:0] : reference distance syntax for delta value0 be used</li> </ul> <p>JPEG:</p> <ul style="list-style-type: none"> <li>[31:27] : tab2:code words of length 4</li> <li>[26:23] : tab2:code words of length 3</li> <li>[21:19] : tab2:code words of length 2</li> <li>[17:16] : tab2:code words of length 1</li> <li>[15:8] : tab1:code words of length 16</li> <li>[7:0] : tab1:code words of length 15</li> </ul> <p>VC-1:</p> <ul style="list-style-type: none"> <li>[24] : enable for intensity compensation 3</li> <li>[23:16] : intensity compensation's iscale value</li> <li>[15:0] : intensity compensation's ishift value</li> </ul> <p>VP7:</p> <ul style="list-style-type: none"> <li>[29:24] : 1st coef of scan read index</li> <li>[23:18] : 2st coef of scan read index</li> <li>[17:12] : 3st coef of scan read index</li> <li>[11:6] : 4st coef of scan read index</li> <li>[5:0] : 5st coef of scan read index</li> </ul> |

**VDPU SWREG138**

Address: Operational Base + offset (0x0228)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | <p>mfr_reg18</p> <p>MPEG4:</p> <ul style="list-style-type: none"> <li>[26:0] : reference distance syntax for delta value -1 be used</li> </ul> <p>JPEG:</p> <ul style="list-style-type: none"> <li>[31:24] : tab2:code words of length 8</li> <li>[23:16] : tab2:code words of length 7</li> <li>[14:8] : tab2:code words of length 6</li> <li>[5:0] : tab2:code words of length 5</li> </ul> <p>VC-1:</p> <ul style="list-style-type: none"> <li>[24] : enable for intensity compensation 4</li> <li>[23:16] : intensity compensation's iscale value</li> <li>[15:0] : intensity compensation's shift value</li> </ul> <p>VP7:</p> <ul style="list-style-type: none"> <li>[29:24] : 6st coef of scan read index</li> <li>[23:18] : 7st coef of scan read index</li> <li>[17:12] : 8st coef of scan read index</li> <li>[11:6] : 9st coef of scan read index</li> <li>[5:0] : 10st coef of scan read index</li> </ul> |

**VDPU SWREG139**

Address: Operational Base + offset (0x022c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | <p>mfr_reg19</p> <p>MPEG4:</p> <ul style="list-style-type: none"> <li>[26:0] : reference distance syntax for delta value1 be used</li> </ul> <p>JPEG:</p> <ul style="list-style-type: none"> <li>[31:24] : tab2:code words of length 12</li> <li>[23:16] : tab2:code words of length 11</li> <li>[15:8] : tab2:code words of length 10</li> <li>[7:0] : tab2:code words of length 9</li> </ul> <p>VP7:</p> <ul style="list-style-type: none"> <li>[29:24] : 11st coef of scan read index</li> <li>[23:18] : 12st coef of scan read index</li> <li>[17:12] : 13st coef of scan read index</li> <li>[11:6] : 14st coef of scan read index</li> <li>[5:0] : 15st coef of scan read index</li> </ul> |

**VDPU SWREG140**

Address: Operational Base + offset (0x0230)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | <p>mfr_reg20</p> <p>JPEG:</p> <ul style="list-style-type: none"> <li>[31:24] : tab2:code words of length 16</li> <li>[23:16] : tab2:code words of length 15</li> <li>[15:8] : tab2:code words of length 14</li> <li>[7:0] : tab2:code words of length 13</li> </ul> <p>VP7:</p> <ul style="list-style-type: none"> <li>[31:2] : DCT stream MB row 2,2n+1 start address</li> </ul> |

**VDPU SWREG141**

Address: Operational Base + offset (0x0234)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | <p>mfr_reg21</p> <p>JPEG:</p> <ul style="list-style-type: none"> <li>[31:28] : tab1:code words of length 8</li> <li>[27:24] : tab1:code words of length 7</li> <li>[23:20] : tab1:code words of length 6</li> <li>[19:16] : tab1:code words of length 5</li> <li>[15:12] : tab1:code words of length 4</li> <li>[11:8] : tab1:code words of length 3</li> <li>[6:4] : tab1:code words of length 2</li> <li>[1:0] : tab1:code words of length 1</li> </ul> <p>VP7</p> <ul style="list-style-type: none"> <li>[31:2] : DCT stream MB row 2,2n+2 start address</li> </ul> |

**VDPU SWREG142**

Address: Operational Base + offset (0x0238)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | mfr_reg22<br>JPEG:<br>[31:28] : tab1:code words of length 16<br>[27:24] : tab1:code words of length 15<br>[23:20] : tab1:code words of length 14<br>[19:16] : tab1:code words of length 13<br>[15:12] : tab1:code words of length 12<br>[11:8] : tab1:code words of length 11<br>[6:4] : tab1:code words of length 10<br>[1:0] : tab1:code words of length 9<br>VP7<br>[31:2] : DCT stream MB row 2,2n+3 start address |

**VDPU SWREG143**

Address: Operational Base + offset (0x023c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | mfr_reg23<br>JPEG:<br>[31:28] : tab2:code words of length 8<br>[27:24] : tab2:code words of length 7<br>[23:20] : tab2:code words of length 6<br>[19:16] : tab2:code words of length 5<br>[15:12] : tab2:code words of length 4<br>[11:8] : tab2:code words of length 3<br>[6:4] : tab2:code words of length 2<br>[1:0] : tab2:code words of length 1<br>VP7<br>[31:2] : DCT stream MB row 2,2n+4 start address |

**VDPU SWREG144**

Address: Operational Base + offset (0x0240)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | mfr_reg24<br>JPEG:<br>[31:28] : tab2:code words of length 16<br>[27:24] : tab2:code words of length 15<br>[23:20] : tab2:code words of length 14<br>[19:16] : tab2:code words of length 13<br>[15:12] : tab2:code words of length 12<br>[11:8] : tab2:code words of length 11<br>[6:4] : tab2:code words of length 10<br>[1:0] : tab2:code words of length 9<br>VP7<br>[31:2] : DCT stream MB row 2,2n+5 start address |

**VDPU SWREG145**

Address: Operational Base + offset (0x0244)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | mfr_reg25<br>JPEG:<br>[31:28] : tab3:code words of length 8<br>[27:24] : tab3:code words of length 7<br>[23:20] : tab3:code words of length 6<br>[19:16] : tab3:code words of length 5<br>[15:12] : tab3:code words of length 4<br>[11:8] : tab3:code words of length 3<br>[6:4] : tab2:code words of length 2<br>[1:0] : tab3:code words of length 1<br>VC-1:<br>[31:2] : bitplane mb ctrl start address<br>VP7:<br>[31:2] : ctrl data stream start address |

**VDPU SWREG146**

Address: Operational Base + offset (0x0248)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                            |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | mfr_reg26<br>JPEG:<br>[31:28] : tab3:code words of length 16<br>[27:24] : tab3:code words of length 15<br>[23:20] : tab3:code words of length 14<br>[19:16] : tab3:code words of length 13<br>[15:12] : tab3:code words of length 12<br>[11:8] : tab3:code words of length 11<br>[6:4] : tab3:code words of length 10<br>[1:0] : tab3:code words of length 9<br>VP7<br>[31:2] : DCT stream MB row 2,2n+6 start address |

**VDPU SWREG147**

Address: Operational Base + offset (0x024c)

| Bit  | Attr | Reset Value | Description                                                         |
|------|------|-------------|---------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | mfr_reg27<br>VP7<br>[31:2] : DCT stream MB row 2,2n+7 start address |

**VDPU SWREG148**

Address: Operational Base + offset (0x0250)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                        |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | mfr_reg28<br>MPEG4/VC-1/MPEG2/VP7:<br>[31:2] : ref pic index 1 start address<br>JPEG:<br>[7:0] : snapshot |

**VDPU\_SWREG149**

Address: Operational Base + offset (0x0254)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | mfr_reg29<br>VC-1:<br>[24] : enable for intensity compensation 1<br>[23:16] : intensity compensation iscale value<br>[15:0] : intensity compensation ishift value<br>VP7:<br>[31:2] : the segmentation map value start address<br>[1] : enable for segmentation map update<br>[0] : enable for segmentation |

**VDPU\_SWREG150**

Address: Operational Base + offset (0x0258)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | mfr_reg30<br>VC-1:<br>[24] : enable for intensity compensation 2<br>[23:16] : intensity compensation iscale value<br>[15:0] : intensity compensation ishift value<br>VP7:<br>[29:24] : DCT stream partition index 3 of start bit<br>[23:18] : DCT stream partition index 4 of start bit<br>[17:12] : DCT stream partition index 5 of start bit<br>[11:6] : DCT stream partition index 6 of start bit<br>[5:0] : DCT stream partition index 7 of start bit |

**VDPU\_SWREG151**

Address: Operational Base + offset (0x025c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | mfr_reg31<br>VP7:<br>[21:11] : QP2 for VP7<br>[10:0] : QP3 for VP7 |

**VDPU\_SWREG152**

Address: Operational Base + offset (0x0260)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | mfr_reg32<br>VP7:<br>[21:11] : QP4 for VP7<br>[10:0] : QP5 for VP7 |

**VDPU\_SWREG153**

Address: Operational Base + offset (0x0264)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | mfr_reg33<br>VC-1/VP7:<br>[31:22] : prediction filter with set 0,tap3 (also for mpeg4)<br>[21:12] : prediction filter with set 1,tap0<br>[11:2] : prediction filter with set 1,tap1 |

**VDPU\_SWREG154**

Address: Operational Base + offset (0x0268)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | mfr_reg34<br>VC-1/VP7:<br>[31:22] : prediction filter with set 1,tap2<br>[21:12] : prediction filter with set 1,tap3<br>[11:2] : prediction filter with set 2,tap0(no for vc-1) |

**VDPU\_SWREG155**

Address: Operational Base + offset (0x026c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | mfr_reg35<br>VC-1/VP7:<br>[31:22] : prediction filter with set 2,tap1<br>[21:12] : prediction filter with set 2,tap2<br>[11:2] : prediction filter with set 2,tap3 |

**VDPU\_SWREG156**

Address: Operational Base + offset (0x0270)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | mfr_reg36<br>VP7:<br>[31:22] : prediction filter with set 3,tap0<br>[21:12] : prediction filter with set 3,tap1<br>[11:2] : prediction filter with set 3,tap2 |

**VDPU\_SWREG157**

Address: Operational Base + offset (0x0274)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | mfr_reg37<br>VP7:<br>[31:22] : prediction filter with set 3,tap3<br>[21:12] : prediction filter with set 4,tap0<br>[11:2] : prediction filter with set 4,tap1 |

**VDPU\_SWREG158**

Address: Operational Base + offset (0x0278)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | mfr_reg38<br>VP7:<br>[31:22] : prediction filter with set 4,tap2<br>[21:12] : prediction filter with set 4,tap3<br>[11:2] : prediction filter with set 5,tap0 |

**VDPU\_SWREG164\_PERF\_LATENCY\_CTRL0**

Address: Operational Base + offset (0x0290)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------|
| 31:20      | RO          | 0x0                | reserved                                                                                  |
| 19:8       | RW          | 0x000              | sw_rd_latency_thr                                                                         |
| 7:4        | RW          | 0x0                | sw_rd_latency_id                                                                          |
| 3          | RW          | 0x0                | sw_axi_cnt_type<br>sw_axi_cnt_type                                                        |
| 2          | RW          | 0x0                | sw_axi_perf_frm_type<br>1'b0: clear by frame end<br>1'b1: clear by software configuration |
| 1          | W1<br>C     | 0x0                | sw_axi_perf_clr_e<br>1'b0: software clear disable<br>1'b1: software clear enable          |
| 0          | RW          | 0x0                | sw_axi_perf_work_e<br>1'b0: disable<br>1'b1: enable                                       |

**VDPU\_SWREG165\_PERF\_LATENCY\_CTRL1**

Address: Operational Base + offset (0x0294)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                     |
|------------|-------------|--------------------|----------------------------------------|
| 31:12      | RO          | 0x0                | reserved                               |
| 11:8       | RW          | 0x0                | sw_aw_count_id<br>sw_aw_count_id       |
| 7:4        | RW          | 0x0                | sw_ar_count_id<br>sw_ar_count_id       |
| 3          | RW          | 0x0                | sw_aw_cnt_id_type<br>sw_aw_cnt_id_type |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                       |
|------------|-------------|--------------------|------------------------------------------|
| 2          | RW          | 0x0                | sw_ar_cnt_id_type<br>sw_ar_cnt_id_type   |
| 1:0        | RW          | 0x0                | sw_addr_align_type<br>sw_addr_align_type |

**VDPU SWREG166 PERF RD MAX LATENCY NUM0**

Address: Operational Base + offset (0x0298)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>     |
|------------|-------------|--------------------|------------------------|
| 31:16      | RO          | 0x0                | reserved               |
| 15:0       | RO          | 0x0000             | rd_max_latency_num_ch0 |

**VDPU SWREG167 PERF RD LATENCY SAMP NUM**

Address: Operational Base + offset (0x029c)

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

**VDPU SWREG168 PERF RD LATENCY ACC SUM**

Address: Operational Base + offset (0x02a0)

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

**VDPU SWREG169 PERF RD AXI TOTAL BYTE**

Address: Operational Base + offset (0x02a4)

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

**VDPU SWREG170 PERF WR AXI TOTAL BYTE**

Address: Operational Base + offset (0x02a8)

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

**VDPU SWREG171 PERF WORKING CNT**

Address: Operational Base + offset (0x02ac)

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

### 5.4.11 VPU121 MMU Register Summary

| Name                        | Offset | Size | Reset Value | Description                                                                                                                   |
|-----------------------------|--------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------|
| V_CODEC_MMU_DTE_ADDR        | 0x0000 | W    | 0x00000000  | MMU current page Table address<br>It is only can be written when MMU state is disable or page fault or mmu enable stall state |
| V_CODEC_MMU_STATUS          | 0x0004 | W    | 0x00000018  | MMU status register                                                                                                           |
| V_CODEC_MMU_COMMAND         | 0x0008 | W    | 0x00000000  | MMU command register                                                                                                          |
| V_CODEC_MMU_PAGE_FAULT_ADDR | 0x000c | W    | 0x00000000  | MMU logical address of last page fault                                                                                        |
| V_CODEC_MMU_ZAP_ONE_LINE    | 0x0010 | W    | 0x00000000  | MMU Zap cache line register                                                                                                   |
| V_CODEC_MMU_INT_RAW_STAT    | 0x0014 | W    | 0x00000000  | MMU raw interrupt status register                                                                                             |
| V_CODEC_MMU_INT_CLEA_R      | 0x0018 | W    | 0x00000000  | MMU raw interrupt status register                                                                                             |
| V_CODEC_MMU_INT_MASK        | 0x001c | W    | 0x00000000  | MMU raw interrupt status register                                                                                             |
| V_CODEC_MMU_INT_STATUS      | 0x0020 | W    | 0x00000000  | MMU raw interrupt status register                                                                                             |
| V_CODEC_MMU_AUTO_GATING     | 0x0024 | W    | 0x00000001  | mmu auto gating                                                                                                               |

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

### 5.4.12 VPU121 MMU Detail Register Description

#### V\_CODEC\_MMU\_DTE\_ADDR

Address: Operational Base + offset (0x0000)

| Bit  | Attr | Reset Value | Description                                    |
|------|------|-------------|------------------------------------------------|
| 31:0 | RW   | 0x00000000  | MMU_DTE_ADDR<br>MMU current page Table address |

#### V\_CODEC\_MMU\_STATUS

Address: Operational Base + offset (0x0004)

| Bit   | Attr | Reset Value | Description                                                                                  |
|-------|------|-------------|----------------------------------------------------------------------------------------------|
| 31:11 | RO   | 0x0         | reserved                                                                                     |
| 10:6  | RO   | 0x00        | PAGE_FAULT_BUS_ID<br>Index of master responsible for last page fault                         |
| 5     | RO   | 0x0         | PAGE_FAULT_IS_WRITE<br>The direction of access for last page fault:<br>0 = Read<br>1 = Write |
| 4     | RO   | 0x1         | REPLAY_BUFFER_EMPTY<br>1'b1:The MMU replay buffer is empty                                   |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------|
| 3          | RO          | 0x1                | MMU_IDLE<br>The MMU is idle when accesses are being translated and there are no unfinished translated accesses.<br>1'b1: MMU is idle |
| 2          | RO          | 0x0                | STAIL_ACTIVE<br>MMU stall mode currently enabled. The mode is enabled by command<br>1'b1: MMU is in stall active status              |
| 1          | RO          | 0x0                | PAGE_FAULT_ACTIVE<br>MMU page fault mode currently enabled . The mode is enabled by command.<br>1'b1: page fault is active           |
| 0          | RO          | 0x0                | PAGING_ENABLED<br>1'b0: paging is disabled<br>1'b1: Paging is enabled                                                                |

**VCODEC\_MMU\_COMMAND**

Address: Operational Base + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3       | RO          | 0x0                | reserved                                                                                                                                                                                             |
| 2:0        | WO          | 0x0                | MMU_CMD<br>MMU_CMD. This can be:<br>0: MMU_ENABLE_PAGING<br>1: MMU_DISABLE_PAGING<br>2: MMU_ENABLE_STALL<br>3: MMU_DISABLE_STALL<br>4: MMU_ZAP_CACHE<br>5: MMU_PAGE_FAULT_DONE<br>6: MMU_FORCE_RESET |

**VCODEC\_MMU\_PAGE\_FAULT\_ADDR**

Address: Operational Base + offset (0x000c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                            |
|------------|-------------|--------------------|-----------------------------------------------|
| 31:0       | RO          | 0x00000000         | PAGE_FAULT_ADDR<br>address of last page fault |

**VCODEC\_MMU\_ZAP\_ONE\_LINE**

Address: Operational Base + offset (0x0010)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------|
| 31:0       | WO          | 0x00000000         | MMU_ZAP_ONE_LINE<br>address to be invalidated from the page table cache |

**VCODEC\_MMU\_INT\_RAWSTAT**

Address: Operational Base + offset (0x0014)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                      |
|------------|-------------|--------------------|-----------------------------------------|
| 31:2       | RO          | 0x0                | reserved                                |
| 1          | RW          | 0x0                | READ_BUS_ERROR<br>read bus error status |
| 0          | RW          | 0x0                | PAGE_FAULT<br>page fault status         |

**VCODEC\_MMU\_INT\_CLEAR**

Address: Operational Base + offset (0x0018)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                |
|------------|-------------|--------------------|---------------------------------------------------|
| 31:2       | RO          | 0x0                | reserved                                          |
| 1          | WO          | 0x0                | READ_BUS_ERROR<br>write 1 to clear read bus error |
| 0          | WO          | 0x0                | PAGE_FAULT<br>write 1 to page fault clear         |

**VCODEC\_MMU\_INT\_MASK**

Address: Operational Base + offset (0x001c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------|
| 31:2       | RO          | 0x0                | reserved                                                                            |
| 1          | RW          | 0x0                | READ_BUS_ERROR<br>enable the read bus interrupt source when this bit is set to 1'b1 |
| 0          | RW          | 0x0                | PAGE_FAULT<br>enable the page fault interrupt source when this bit is set to 1'b1   |

**VCODEC\_MMU\_INT\_STATUS**

Address: Operational Base + offset (0x0020)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                           |
|------------|-------------|--------------------|----------------------------------------------|
| 31:2       | RO          | 0x0                | reserved                                     |
| 1          | RO          | 0x0                | READ_BUS_ERROR<br>1'b1:read bus error status |
| 0          | RO          | 0x0                | PAGE_FAULT<br>1'b1:page fault                |

**VCODEC\_MMU\_AUTO\_GATING**

Address: Operational Base + offset (0x0024)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------|
| 31:1       | RO          | 0x0                | reserved                                                                |
| 0          | RW          | 0x1                | mmu_auto_clkgating<br>when it is 1'b1, the mmu will auto gating it self |

**5.4.13 VDPU121 CACHE Register Summary**

| Name                     | Offset | Size | Reset Value | Description                                                                                                                                                                                                                                                                                                                                            |
|--------------------------|--------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| pref_cache VERSION       | 0x0000 | W    | 0xcac20101  | VERSION register                                                                                                                                                                                                                                                                                                                                       |
| pref_cache SIZE          | 0x0004 | W    | 0x06110206  | L2 cache SIZE                                                                                                                                                                                                                                                                                                                                          |
| pref_cache STATUS        | 0x0008 | W    | 0x00000000  | Status register                                                                                                                                                                                                                                                                                                                                        |
| pref_cache COMMAND       | 0x0010 | W    | 0x00000000  | Command setting register                                                                                                                                                                                                                                                                                                                               |
| pref_cache CLEAR_PAGE    | 0x0014 | W    | 0x00000000  | clear page register                                                                                                                                                                                                                                                                                                                                    |
| pref_cache MAX_READS     | 0x0018 | W    | 0x0000001c  | maximum read register                                                                                                                                                                                                                                                                                                                                  |
| pref_cache PERFCNT_SR_C0 | 0x0020 | W    | 0x00000000  | performance counter 0 source register                                                                                                                                                                                                                                                                                                                  |
| pref_cache PERFCNT_VAL_0 | 0x0024 | W    | 0x00000000  | performance counter 0 value register                                                                                                                                                                                                                                                                                                                   |
| pref_cache PERFCNT_SR_C1 | 0x0028 | W    | 0x00000000  | This register holds all the possible source values for Performance Counter 00: total clock cycles1: active clock cycles2: read transactions, master3: word reads, master4: read transactions, slave5: word reads, slave6: read hit, slave7: read misses, slave8: read invalidates, slave9: cacheable read transactions, slave10: bad hit number, slave |
| pref_cache PERFCNT_VAL_1 | 0x002c | W    | 0x00000000  | performance counter 1 value register                                                                                                                                                                                                                                                                                                                   |

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

#### 5.4.14 VDPU121 CACHE Detail Register Description

##### pref\_cache VERSION

Address: Operational Base + offset (0x0000)

| Bit   | Attr | Reset Value | Description                            |
|-------|------|-------------|----------------------------------------|
| 31:16 | RO   | 0xcac2      | PRODUCT_ID<br>Field0000 Description    |
| 15:8  | RO   | 0x01        | VERSION_MAJOR<br>Field0000 Description |
| 7:0   | RO   | 0x01        | VERSION_MINOR<br>Field0000 Description |

##### pref\_cache SIZE

Address: Operational Base + offset (0x0004)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                    |
|------------|-------------|--------------------|-------------------------------------------------------|
| 31:24      | RO          | 0x06               | External_bus_width<br>Log2 external bus width in bits |
| 23:16      | RO          | 0x11               | CACHE_SIZE<br>Log2 cache size in bytes                |
| 15:8       | RO          | 0x02               | ASSOCIATIVITY<br>Log2 associativity                   |
| 7:0        | RO          | 0x06               | LINE_SIZE<br>Log2 line size in bytes                  |

**pref\_cache\_STATUS**

Address: Operational Base + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 31:2       | RO          | 0x0                | reserved                                                 |
| 1          | RO          | 0x0                | DATA_BUSY<br>set when the cache is busy handling data    |
| 0          | RO          | 0x0                | CMD_BUSY<br>set when the cache is busy handling commands |

**pref\_cache\_COMMAND**

Address: Operational Base + offset (0x0010)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6       | RO          | 0x0                | reserved                                                                                                                                   |
| 5:4        | RW          | 0x0                | sw_addrb_sel<br>2'b00: to sel b[14:6]<br>2'b01: to sel b[15:9], b[7:6]<br>2'b10: to sel b[16:10], b[7:6]<br>2'b11: to sel b[17:11], b[7:6] |
| 3          | RO          | 0x0                | reserved                                                                                                                                   |
| 2:0        | WO          | 0x0                | COMMAND<br>The possible command is<br>1 = Clear entire cache                                                                               |

**pref\_cache\_CLEAR\_PAGE**

Address: Operational Base + offset (0x0014)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------|
| 31:0       | WO          | 0x00000000         | CLEAR_PAGE<br>writing an address, invalidates all lines in that page from the cache |

**pref\_cache\_MAX\_READS**

Address: Operational Base + offset (0x0018)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------|
| 31:5       | RO          | 0x0                | reserved                                                                      |
| 4:0        | RW          | 0x1c               | MAX_READS<br>Limit the number of outstanding read transactions to this amount |

**pref cache PERFCNT\_SRC0**

Address: Operational Base + offset (0x0020)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                          |
| 3:0        | RW          | 0x0                | PERFCNT_SRC0<br>This register holds all the possible source values for Performance Counter 0<br>0: total clock cycles<br>1: active clock cycles<br>2: read transactions, master<br>3: word reads, master<br>4: read transactions, slave<br>5: word reads, slave<br>6: read hit, slave<br>7: read misses, slave<br>8: read invalidates, slave<br>9: cacheable read transactions, slave<br>10: bad hit nmber, slave |

**pref cache PERFCNT\_VAL0**

Address: Operational Base + offset (0x0024)

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

**pref cache PERFCNT\_SRC1**

Address: Operational Base + offset (0x0028)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 3:0        | RW          | 0x0                | <p>PERFCNT_SRC1</p> <p>This register holds all the possible source values for Performance Counter 1</p> <ul style="list-style-type: none"> <li>0: total clock cycles</li> <li>1: active clock cycles</li> <li>2: read transactions, master</li> <li>3: word reads, master</li> <li>4: read transactions, slave</li> <li>5: word reads, slave</li> <li>6: read hit, slave</li> <li>7: read misses, slave</li> <li>8: read invalidates, slave</li> <li>9: cacheable read transactions, slave</li> <li>10: bad hit number, slave</li> </ul> |

**pref cache PERFCNT VAL1**

Address: Operational Base + offset (0x002c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                     |
|------------|-------------|--------------------|--------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | <p>PERFCNT_VAL1</p> <p>Performance counter 1 value</p> |

## 5.5 Application Notes

### 5.5.1 HEVC Configuration flow

1. Write the hevc\_vpu\_sel bit in the GRF\_SOC\_CONx register with "1" to choose HEVC to work.
2. Prepare the data in the DDR.
3. Set the HEVC general system configuration in HEVC.swreg2, such as working mode, in/out endian.
4. Set the picture parameters with HEVC.swreg3.
5. Set the input and output data base address and HEVC reference configuration with HEVC.swreg4~HEVC.swreg43.
6. If CABAC error detection is desired, set the HEVC.swreg44 to enable the corresponding error detection.
7. Set the interrupt configuration and start the HEVC with HEVC.swreg1.
8. Wait for the frame interrupt, and then get the processed results in the target DDR
9. Clear all the interrupts, and repeat Process2~Process8 to start a new frame decoding if the decoding is not finished yet.



Fig. 5-6 HEVC Common Configuration Flow

### 5.5.2 VPU121 Configuration flow

- 1.Because HEVC and VPU share the same memory and ahb bus and some of axi bus, we should set the hevc\_vpu\_sel bit in GRF\_SOC\_CONx to 1'b0 to select VPU to work.
- 2.Prepare the decoder data in the DDR memory, And in decoder other than JPEG decoder, the input stream buffer should at least contain a slice or a frame data, otherwise the decoder will produce an interrupt and show error and then reset itself.
- 3.Config all the registers will be used. and please notice that which be list as follows:
  - In encoder---- We can configure the registers to control the input picture data format (such as endian and swap), but some input data format are fixed, such as cabac\_table data. And the register VEPU\_SWREG64~95 are JPEG quantization registers. They are write only registers. When you want to write these registers, you should first set VEPU\_SWREG14[0] to 1'b0 and VEPU\_SWREG14[2:1] to 2'b10( select JPEG mode).
  - In decoder---- The decoder can support ref buffer mode or cacheable mode, but they can't be both enabled. We can config the swreg57[6],swreg57[7] to enable cache and config the swreg51 to control the ref buffer.
- 4.You should config VDPU\_SWREG1[0] as 1'b1 to enable video decoder. And config VDPU\_SWREG60[0] as 1'b1 to enable pp. If pp performed in pipeline with decoder, you should config VDPU\_SWREG60[1] as 1'b1 and then config VDPU\_SWREG1[0] as 1'b1 to enable decoder and pp. VEPU\_SWREG14[0] set to 1'b1 to enable encoder.
- 5.Wait for the frame interrupt, and then check if the frame decoder ready interrupt is right or not, after that, you can get the processed results in the target DDR
- 6.Clear all the interrupts, repeat step 2~5 to start a new frame decoder or encoder.

## Chapter 6 Video Input Processor (VIP)

### 6.1 Overview

The Video Input Processor, receives the data from Camera or CCIR656 encoder, and transfers the data into system main memory by AXI bus.

The Video Input Processor supports following features:

- Support YCbCr422 8bit input
- Support Raw 8bit/10bit/12bit 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 error/terminate interrupt and combined interrupt output
- Support clk/vsync/href polarity configurable
- Support one frame stop/ping-pong mode
- Support mmu

### 6.2 Block Diagram



Fig. 6-1 VIP block diagram

The VIP 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
- DMA
- Control the operation of AXI Master

### 6.3 Function Description

This chapter is used to illustrate the operational behavior of how VIP works. If YUV422 or ccir656 signal is received from external devices, VIP translate it into YUV422/420 data, and separate the data to Y and UV data, then store them to different memory via AXI bus separately. But if raw data is received, there are not any translations happened, the 8 data is considered as 16bit data and write directly to memory.

#### 6.3.1 Support Vsync high active or low active

- Vsync Low active as below

Vertical sensor timing (line by line)

Fig. 6-2 Timing diagram for VIP when vsync low active

- Vsync High active



Fig. 6-3 Timing diagram for VIP when vsync high active

**6.3.2 Support href high active or low active**

- Href high active



Fig. 6-4 Timing diagram for VIP when href high active

- Href Low active



Fig. 6-5 Timing diagram for VIP when href low active

- Y first



Fig. 6-6 Timing diagram for VIP when Y data first

- U first



Fig. 6-7 Timing diagram for VIP when U data first

### **6.3.3 Support CCIR656 (NTSC and PAL)**



Fig. 6-8 CCIR656 timing

#### **6.3.4 Support Raw data (8-bit) or JPEG**

## Pixel Data Timing Example



Fig. 6-9 Raw Data or JPEG Timing

VIP module can work in three modes: one frame stop mode, ping-pong mode.

# One frame stop mode

In this mode, configure the parameter WORK\_MODE to one frame stop mode. After one frame captured, VIP will automatic stop. After capturing, the image Y, UV data will be stored at main memory location defined by VIP\_FRM0\_ADDR\_Y, FRM0\_ADDR\_UV separately.

## Ping-Pong mode

After one frame(F1) captured, VIP will start to capture the next frame(F2) automatically, and host must assign new address pointer of frame1 and clear the frame1 status, thus VIP 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 VIP will cover the pre-frame data stored in the memory with the following frame data.

## 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 JPEG mode, the width is a halfword no matter the data source is 8 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.

## 6.4 Register Description

#### **6.4.1 Registers Summary**

| Name        | Offset | Size | Reset Value | Description          |
|-------------|--------|------|-------------|----------------------|
| VIP_CTRL    | 0x0000 | W    | 0x00000000  | VIP control          |
| VIP_INTEN   | 0x0004 | W    | 0x00000000  | VIP interrupt status |
| VIP_INTSTAT | 0x0008 | W    | 0x00000000  | VIP interrupt status |

| Name                | Offset | Size | Reset Value | Description                                                                                                                 |
|---------------------|--------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------|
| VIP FOR             | 0x000c | W    | 0x00000000  | VIP format                                                                                                                  |
| VIP FRM0 ADDR Y     | 0x0014 | W    | 0x00000000  | VIP frame0 y address                                                                                                        |
| VIP FRM0 ADDR UV    | 0x0018 | W    | 0x00000000  | VIP frame0 uv address                                                                                                       |
| VIP FRM1 ADDR Y     | 0x001c | W    | 0x00000000  | VIP frame1 y address                                                                                                        |
| VIP FRM1 ADDR UV    | 0x0020 | W    | 0x00000000  | VIP frame1 uv address                                                                                                       |
| VIP VIR LINE WIDTH  | 0x0024 | W    | 0x00000000  | VIP virtual line width                                                                                                      |
| VIP SET SIZE        | 0x0028 | W    | 0x000002d0  | VIP frame set size                                                                                                          |
| VIP CROP            | 0x0044 | W    | 0x00000000  | VIP crop start point                                                                                                        |
| VIP SCL CTRL        | 0x0048 | W    | 0x00000000  | CIF scale control                                                                                                           |
| VIP FIFO ENTRY      | 0x0054 | W    | 0x00000000  | VIP FIFO entry                                                                                                              |
| VIP FRAME STATUS    | 0x0060 | W    | 0x00000000  | VIP frame status                                                                                                            |
| VIP CUR DST         | 0x0064 | W    | 0x00000000  | VIP current destination address                                                                                             |
| VIP LAST LINE       | 0x0068 | W    | 0x00000000  | VIP last frame line number                                                                                                  |
| VIP LAST PIX        | 0x006c | W    | 0x00000000  | VIP last line pixel number                                                                                                  |
| VIP DTE ADDR        | 0x0800 | W    | 0x00000000  | MMU current page Table address. It is only can be written when MMU state is disable or page fault or mmu enable stall state |
| VIP STATUS          | 0x0804 | W    | 0x00000000  | MMU status register                                                                                                         |
| VIP COMMAND         | 0x0808 | W    | 0x00000000  | MMU command register                                                                                                        |
| VIP PAGE FAULT ADDR | 0x080c | W    | 0x00000000  | MMU logical address of last page fault                                                                                      |
| VIP ZAP ONE LINE    | 0x0810 | W    | 0x00000000  | MMU Zap cache line register                                                                                                 |
| VIP INT RAWSTAT     | 0x0814 | W    | 0x00000000  | MMU raw interrupt status register                                                                                           |
| VIP INT CLEAR       | 0x0818 | W    | 0x00000000  | MMU raw interrupt status register                                                                                           |
| VIP INT MASK        | 0x081c | W    | 0x00000000  | MMU raw interrupt status register                                                                                           |
| VIP INT STATUS      | 0x0820 | W    | 0x00000000  | MMU raw interrupt status register                                                                                           |
| VIP AUTO GATING     | 0x0824 | W    | 0x00000000  | MMU auto gating                                                                                                             |

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

## 6.4.2 Detail Register Description

### VIP CTRL

Address: Operational Base + offset (0x0000)

| Bit   | Attr | Reset Value | Description                                                       |
|-------|------|-------------|-------------------------------------------------------------------|
| 31:16 | RO   | 0x0         | reserved                                                          |
| 15:12 | RW   | 0x0         | AXI_BURST_TYPE<br>Axi master burst byte.<br>4'h0-4'hf : burst1~16 |
| 11:3  | RO   | 0x0         | reserved                                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 2:1        | RW          | 0x0                | WORK_MODE<br>Working mode.<br>2'b00 : one frame stop mode<br>2'b01 : ping-pong mode<br>2'b10 : line loop mode<br>2'b11 : reserved |
| 0          | RW          | 0x0                | CAP_EN<br>Capture enable.<br>1'b0 : disable<br>1'b1 : enable                                                                      |

**VIP\_INTEN**

Address: Operational Base + offset (0x0004)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                           |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------|
| 31:10      | RO          | 0x0                | reserved                                                                                                                     |
| 9          | RW          | 0x0                | PST_INF_FRAME_END_EN<br>Frame end after interface FIFO interrupt enable.<br>1'b0 : disable<br>1'b1 : enable                  |
| 8          | RW          | 0x0                | PRE_INF_FRAME_END_EN<br>Frame end before interface FIFO interrupt enable.<br>1'b0 : disable<br>1'b1 : enable                 |
| 7          | RO          | 0x0                | reserved                                                                                                                     |
| 6          | W1C         | 0x0                | BUS_ERR_EN<br>Axi master or ahb slave response error interrupt enable.<br>1'b0 : disable<br>1'b1 : enable                    |
| 5          | RW          | 0x0                | DFIFO_OF_EN<br>DMA FIFO overflow interrupt enable.<br>1'b0 : disable<br>1'b1 : enable                                        |
| 4          | RW          | 0x0                | IFIFO_OF_EN<br>Interface FIFO overflow interrupt enable.<br>1'b0 : disable<br>1'b1 : enable                                  |
| 3          | W1C         | 0x0                | PIX_ERR_EN<br>The pixel number of last line not equal to the set height interrupt enable.<br>1'b0 : disable<br>1'b1 : enable |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------|
| 2          | W1<br>C     | 0x0                | LINE_ERR_EN<br>The line number of last frame not equal to the set height interrupt enable.<br>1'b0 : disable<br>1'b1 : enable |
| 1          | W1<br>C     | 0x0                | LINE_END_EN<br>Line end interrupt enable.<br>1'b0 : disable<br>1'b1 : enable                                                  |
| 0          | RW          | 0x0                | DMA_FRAME_END_EN<br>DMA frame end interrupt enable.<br>1'b0 : disable<br>1'b1 : enable                                        |

**VIP\_INTSTAT**

Address: Operational Base + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------|
| 31:10      | RO          | 0x0                | reserved                                                                                                                   |
| 9          | RW          | 0x0                | PST_INF_FRAME_END<br>Frame end after interface FIFO interrupt.<br>1'b0 : no interrupt<br>1'b1 : interrupt                  |
| 8          | RW          | 0x0                | PRE_INF_FRAME_END<br>Frame end before interface FIFO interrupt.<br>1'b0 : no interrupt<br>1'b1 : interrupt                 |
| 7          | RO          | 0x0                | reserved                                                                                                                   |
| 6          | W1<br>C     | 0x0                | BUS_ERR<br>Axi master or ahb slave response error interrupt.<br>1'b0 : no interrupt<br>1'b1 : interrupt                    |
| 5          | RW          | 0x0                | DFIFO_OF<br>DMA FIFO overflow interrupt.<br>1'b0 : no interrupt<br>1'b1 : interrupt                                        |
| 4          | RW          | 0x0                | IFIFO_OF<br>Interface FIFO overflow interrupt.<br>1'b0 : no interrupt<br>1'b1 : interrupt                                  |
| 3          | W1<br>C     | 0x0                | PIX_ERR<br>The pixel number of last line not equal to the set height interrupt.<br>1'b0 : no interrupt<br>1'b1 : interrupt |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------|
| 2          | W1<br>C     | 0x0                | LINE_ERR<br>The line number of last frame not equal to the set height interrupt.<br>1'b0 : no interrupt<br>1'b1 : interrupt |
| 1          | W1<br>C     | 0x0                | LINE_END<br>Line end interrupt.<br>1'b0 : no interrupt<br>1'b1 : interrupt                                                  |
| 0          | W1<br>C     | 0x0                | DMA_FRAME_END<br>DMA frame end interrupt.<br>1'b0 : no interrupt<br>1'b1 : interrupt                                        |

**VIP FOR**

Address: Operational Base + offset (0x000c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20      | RO          | 0x0                | reserved                                                                                                                                   |
| 19         | RW          | 0x0                | UV_STORE_ORDER<br>UV storage order.<br>1'b0 : UVUV<br>1'b1 : VUVU                                                                          |
| 18         | RW          | 0x0                | RAW_END<br>Raw data endian.<br>1'b0 : little end<br>1'b1 : big end                                                                         |
| 17         | RW          | 0x0                | OUT_420_ORDER<br>Output 420 order.<br>1'b0 : UV in the even line<br>1'b1 : UV in the odd line<br>Note: The first line is even line(line 0) |
| 16         | RW          | 0x0                | OUTPUT_420<br>Output 420 or 422.<br>1'b0 : output is 422<br>1'b1 : output is 420                                                           |
| 15         | RO          | 0x0                | reserved                                                                                                                                   |
| 14:13      | RW          | 0x0                | MIPI_MODE<br>Mipi mode:<br>2'b00 : 32 bit bypass mode<br>2'b01 : rgb mode<br>2'b10 : yuv mode<br>2'b11 : reserve                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| 12:11      | RW          | 0x0                | RAW_WIDTH<br>Raw data width.<br>2'b00 : 8bit raw data<br>2'b01 : 10bit raw data<br>2'b10 : 12bit raw data<br>2'b11 : reserve                    |
| 10         | RW          | 0x0                | JPEG_MODE<br>JPEG mode.<br>1'b0 : other mode<br>1'b1 : mode1                                                                                    |
| 9          | RW          | 0x0                | FIELD_ORDER<br>CCIR input order.<br>1'b0 : odd field first<br>1'b1 : even field first                                                           |
| 8          | RW          | 0x0                | IN_420_ORDER<br>420 input order.<br>1'b0 : UV in the even line<br>1'b1 : UV in the odd line<br>Note: The first line is even line(line 0)        |
| 7          | RW          | 0x0                | INPUT_420<br>Input 420 or 422.<br>1'b0 : 422<br>1'b1 : 420                                                                                      |
| 6:5        | RW          | 0x0                | YUV_IN_ORDER<br>YUV input order:<br>2'b00 : UYVY<br>2'b01 : YVYU<br>2'b10 : VYUY<br>2'b11 : YUYV                                                |
| 4:2        | RW          | 0x0                | INPUT_MODE<br>Input mode:<br>3'b000 : YUV<br>3'b010 : PAL<br>3'b011 : NTSC<br>3'b100 : RAW<br>3'b101 : JPEG<br>3'b110 : MIPI<br>Other : invalid |
| 1          | RW          | 0x0                | HREF_POL<br>Href input polarity:<br>1'b0 : high active<br>1'b1 : low active                                                                     |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------|
| 0          | RW          | 0x0                | VSYNC_POL<br>Vsync input polarity:<br>1'b0 : low active<br>1'b1 : high active |

**VIP FRM0 ADDR Y**

Address: Operational Base + offset (0x0014)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                  |
|------------|-------------|--------------------|-------------------------------------|
| 31:0       | RW          | 0x00000000         | FRM0_ADDR_Y<br>VIP frame0 y address |

**VIP FRM0 ADDR UV**

Address: Operational Base + offset (0x0018)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                    |
|------------|-------------|--------------------|---------------------------------------|
| 31:0       | RW          | 0x00000000         | FRM0_ADDR_UV<br>VIP frame0 uv address |

**VIP FRM1 ADDR Y**

Address: Operational Base + offset (0x001c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                  |
|------------|-------------|--------------------|-------------------------------------|
| 31:0       | RW          | 0x00000000         | FRM1_ADDR_Y<br>VIP frame1 y address |

**VIP FRM1 ADDR UV**

Address: Operational Base + offset (0x0020)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                    |
|------------|-------------|--------------------|---------------------------------------|
| 31:0       | RW          | 0x00000000         | FRM1_ADDR_UV<br>VIP frame1 uv address |

**VIP VIR LINE WIDTH**

Address: Operational Base + offset (0x0024)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                       |
|------------|-------------|--------------------|------------------------------------------|
| 31:15      | RO          | 0x0                | reserved                                 |
| 14:0       | RW          | 0x0000             | VIR_LINE_WIDTH<br>VIP virtual line width |

**VIP SET SIZE**

Address: Operational Base + offset (0x0028)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>       |
|------------|-------------|--------------------|--------------------------|
| 31:29      | RO          | 0x0                | reserved                 |
| 28:16      | RW          | 0x0000             | SET_HEIGHT<br>Set height |
| 15:13      | RO          | 0x0                | reserved                 |
| 12:0       | RW          | 0x02d0             | SET_WIDTH<br>Set width   |

**VIP CROP**

Address: Operational Base + offset (0x0044)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>       |
|------------|-------------|--------------------|--------------------------|
| 31:29      | RO          | 0x0                | reserved                 |
| 28:16      | RW          | 0x0000             | START_Y<br>Start x point |
| 15:13      | RO          | 0x0                | reserved                 |
| 12:0       | RW          | 0x0000             | START_X<br>Start y point |

**VIP SCL CTRL**

Address: Operational Base + offset (0x0048)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------|
| 31:7       | RO          | 0x0                | reserved                                                               |
| 6          | RW          | 0x0                | MIPI_32B_BP<br>Mipi 32bit bypass.<br>1'b0 : no bypass<br>1'b1 : bypass |
| 5          | RW          | 0x0                | RAW_16B_BP<br>Raw 16bit bypass.<br>1'b0 : no bypass<br>1'b1 : bypass   |
| 4          | RW          | 0x0                | YUV_16B_BP<br>YUV 16bit bypass.<br>1'b0 : no bypass<br>1'b1 : bypass   |
| 3:0        | RO          | 0x0                | reserved                                                               |

**VIP FIFO ENTRY**

Address: Operational Base + offset (0x0054)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------|
| 31:18      | RO          | 0x0                | reserved                                                        |
| 17:9       | RW          | 0x000              | UV_FIFO_ENTRY<br>Valid UV double word in FIFO.<br>Write 0 clear |
| 8:0        | RO          | 0x000              | Y_FIFO_ENTRY<br>Valid Y double word in FIFO.<br>Write 0 clear   |

**VIP FRAME STATUS**

Address: Operational Base + offset (0x0060)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                             |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | FRAME_NUM<br>Complete frame number.<br>write 0 to clear                                        |
| 15:2       | RO          | 0x0                | reserved                                                                                       |
| 1          | RO          | 0x0                | F1_STS<br>Frame 1 status.<br>1'b0 : frame 1 not ready<br>1'b1 : frame 1 ready<br>Write 0 clear |
| 0          | RO          | 0x0                | F0_STS<br>Frame 0 status.<br>1'b0 : frame 0 not ready<br>1'b1 : frame 0 ready<br>Write 0 clear |

**VIP CUR DST**

Address: Operational Base + offset (0x0064)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | CUR_DST<br>Current destination address.<br>Maybe not the current, because the clock synchronization |

**VIP LAST LINE**

Address: Operational Base + offset (0x0068)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                         |
|------------|-------------|--------------------|--------------------------------------------|
| 31:13      | RO          | 0x0                | reserved                                   |
| 12:0       | RO          | 0x0000             | LAST_LINE_NUM<br>Line number of last frame |

**VIP LAST PIX**

Address: Operational Base + offset (0x006c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:29      | RO          | 0x0                | reserved                             |
| 28:16      | RW          | 0x0000             | LAST_UV_NUM<br>Y number of last line |
| 15:13      | RO          | 0x0                | reserved                             |
| 12:0       | RO          | 0x0000             | LAST_Y_NUM<br>Y number of last line  |

**VIP DTE ADDR**

Address: Operational Base + offset (0x0800)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                             |
|------------|-------------|--------------------|------------------------------------------------|
| 31:0       | RW          | 0x00000000         | MMU_DTE_ADDR<br>MMU current page Table address |

**VIP STATUS**

Address: Operational Base + offset (0x0804)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                       |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:11      | RO          | 0x0                | reserved                                                                                                                                                 |
| 10:6       | RO          | 0x00               | PAGE_FAULT_BUS_ID<br>Page fault bus id.<br>Index of master responsible for last page fault                                                               |
| 5          | RO          | 0x0                | PAGE_FAULT_IS_WRITE<br>Page fault access.<br>The direction of access for last page fault:<br>1'b0 = Read<br>1'b1 = Write                                 |
| 4          | RO          | 0x0                | REPLAY_BUFFER_EMPTY<br>Replay buffer empty status.<br>1'b1: The MMU replay buffer is empty                                                               |
| 3          | RO          | 0x0                | MMU_IDLE<br>MMU idle status.<br>The MMU is idle when accesses are being translated and there are no unfinished translated accesses.<br>1'b1: MMU is idle |
| 2          | RO          | 0x0                | STAIL_ACTIVE<br>Stall active status.<br>MMU stall mode currently enabled. The mode is enabled by command.<br>1'b1: MMU is in stall active status         |
| 1          | RO          | 0x0                | PAGE_FAULT_ACTIVE<br>Page fault active status. MMU page fault mode currently enabled .<br>The mode is enabled by command.<br>1'b1: page fault is active  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------|
| 0          | RW          | 0x0                | PAGING_ENABLED<br>Paging enabled status.<br>1'b0: paging is disabled<br>1'b1: Paging is enabled |

**VIP COMMAND**

Address: Operational Base + offset (0x0808)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3       | RO          | 0x0                | reserved                                                                                                                                                                                                                 |
| 2:0        | RW          | 0x0                | MMU_CMD<br>MMU cmd.This can be:<br>3'h0: MMU_ENABLE_PAGING<br>3'h1: MMU_DISABLE_PAGING<br>3'h2: MMU_ENABLE_STALL<br>3'h3: MMU_DISABLE_STALL<br>3'h4: MMU_ZAP_CACHE<br>3'h5: MMU_PAGE_FAULT_DONE<br>3'h6: MMU_FORCE_RESET |

**VIP PAGE FAULT ADDR**

Address: Operational Base + offset (0x080c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | PAGE_FAULT_ADDR<br>Page fault addr.<br>Address of last page fault |

**VIP ZAP ONE LINE**

Address: Operational Base + offset (0x0810)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------|
| 31:0       | WO          | 0x00000000         | MMU_ZAP_ONE_LINE<br>Zap one line.<br>Address to be invalidated from the page table cache |

**VIP INT\_RAWSTAT**

Address: Operational Base + offset (0x0814)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                      |
|------------|-------------|--------------------|-----------------------------------------|
| 31:2       | RO          | 0x0                | reserved                                |
| 1          | RW          | 0x0                | READ_BUS_ERROR<br>Read bus error status |
| 0          | RW          | 0x0                | PAGE_FAULT<br>Page fault status         |

**VIP INT CLEAR**

Address: Operational Base + offset (0x0818)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------|
| 31:2       | RO          | 0x0                | reserved                                                                |
| 1          | WO          | 0x0                | READ_BUS_ERROR<br>Read bus error.<br>Write 1'b1 to clear read bus error |
| 0          | RW          | 0x0                | PAGE_FAULT<br>Page fault clear.<br>Write 1'b1 to page fault clear       |

**VIP INT MASK**

Address: Operational Base + offset (0x081c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------|
| 31:2       | RO          | 0x0                | reserved                                                                                            |
| 1          | RW          | 0x0                | READ_BUS_ERROR<br>Read bus error. Enable the read bus interrupt source when this bit is set to 1'b1 |
| 0          | RW          | 0x0                | PAGE_FAULT<br>Page fault mask. Enable the page fault interrupt source when this bit is set to 1'b1  |

**VIP INT STATUS**

Address: Operational Base + offset (0x0820)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------|
| 31:2       | RO          | 0x0                | reserved                                                               |
| 1          | RO          | 0x0                | READ_BUS_ERROR<br>Read bus error status.<br>1'b1:read bus error status |
| 0          | RO          | 0x0                | PAGE_FAULT<br>Page fault status.<br>1'b1:page fault                    |

**VIP AUTO GATING**

Address: Operational Base + offset (0x0824)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------|
| 31:1       | RO          | 0x0                | reserved                                                                |
| 0          | RW          | 0x0                | MMU_AUTO_CLKGATING<br>When it is 1'b1, the mmu will auto gating it self |

## 6.5 Interface Description

| <b>Module Pin</b> | <b>Dir</b> | <b>Pad Name</b>                               | <b>IOMUX Setting</b>           |
|-------------------|------------|-----------------------------------------------|--------------------------------|
| vip_clkout        | O          | IO_CIFClkoutm0_CLKout_ethernet_GPIO2_B3vccio3 | GRF_GPIO2B_IOMUX_L[14:12]=3'b1 |
|                   | O          | IO_LCDCd20_PDMsdi1_CIFClkoutm1_GPIO3D0vccio4  | GRF_GPIO3D_IOMUX_L[2:0]=3'b11  |
| vip_clkin         | I          | IO_CIFClkinm0_GPIO2B2vccio3                   | GRF_GPIO2B_IOMUX_L[10:8]=3'b1  |

| <b>Module Pin</b> | <b>Dir</b> | <b>Pad Name</b>                                              | <b>IOMUX Setting</b>            |
|-------------------|------------|--------------------------------------------------------------|---------------------------------|
|                   | I          | IO_LCDCd23_PDMsdi0m0_CIFclk1nm1_ISPfl_trig_GPIO3D3vccio4     | GRF_GPIO3D_IOMUX_L[14:12]=3'b11 |
| vip_href          | I          | IO_CIFhrefm0_GPIO2B1vccio3                                   | GRF_GPIO2B_IOMUX_L[6:4]=3'b1    |
|                   | I          | IO_LCDCd22_PDMsdi3_CIFhrefm1_ISPflash_trig_GPIO3D2vccio3     | GRF_GPIO3D_IOMUX_L[10:8]=3'b11  |
| vip_vsync         | I          | IO_CIFVsyncm0_GPIO2B0vccio3                                  | GRF_GPIO2B_IOMUX_L[2:0]=3'b1    |
|                   | I          | IO_LCDCd21_PDMsdi2_CIFVsyncm1_ISPprelight_trig_GPIO3D1vccio4 | GRF_GPIO3D_IOMUX_L[6:4]=3'b11   |
| vip_data0         | I          | IO_ART2txm1_GPIO2B4vccio3                                    | GRF_GPIO2B_IOMUX_H[2:0]=3'b1    |
|                   | I          | IO_LCDChsyncm0_I2S22ch_mclk_UART5rx_GPIO3A1vccio4            | GRF_GPIO3A_IOMUX_L[6:4]=3'b11   |
| vip_data1         | I          | IO_UARTrxm1_GPIO2B6vccio3                                    | GRF_GPIO2B_IOMUX_H[10:8]=3'b1   |
|                   | I          | IO_LCDCVsyncm0_I2S22ch_sclk_UART5tx_GPIO3A2vccio4            | GRF_GPIO3A_IOMUX_L[10:8]=3'b11  |
| vip_data2         | I          | IO_CIFd2m0_GPIO2A0vccio3                                     | GRF_GPIO2A_IOMUX_L[2:0]=3'b1    |
|                   | I          | IO_LCDCdenm0_I2S22ch_lrcck_CIFd2m1_UART5cts_GPIO3A3vccio4    | GRF_GPIO3A_IOMUX_L[14:12]=3'b11 |
| vip_data3         | I          | IO_CIFd3m0_GPIO2A1vccio3                                     | GRF_GPIO2A_IOMUX_L[6:4]=3'b1    |
|                   | I          | IO_LCDCd1m0_I2S22ch_sdi_CIFd3m1_UART5rts_GPIO3A5vccio4       | GRF_GPIO3A_IOMUX_H[6:4]=3'b11   |
| vip_data4         | I          | IO_CIFd4m0_GPIO2A2vccio3                                     | GRF_GPIO2A_IOMUX_L[10:8]=3'b1   |
|                   | I          | IO_LCDCd3m0_I2S22ch_sdo_CIFd4m1_GPIO3A7vccio4                | GRF_GPIO3A_IOMUX_H[14:12]=3'b11 |
| vip_data5         | I          | IO_CIFd5m0_GPIO2A3vccio3                                     | GRF_GPIO2A_IOMUX_L[14:12]=3'b1  |
|                   | I          | IO_LCDCd4m0_I2S08ch_sdi3_CIFd5m1_GPIO3B0vccio4               | GRF_GPIO3B_IOMUX_L[2:0]=3'b11   |
| vip_data6         | I          | IO_CIFd6m0_GPIO2A4vccio3                                     | GRF_GPIO2A_IOMUX_H[2:0]=3'b1    |
|                   | I          | IO_LCDCd5m0_I2S08ch_sdi2_CIFd6m1_SPI1csn_GPIO3B1vccio4       | GRF_GPIO3B_IOMUX_L[6:4]=3'b11   |
| vip_data7         | I          | IO_CIFd7m0_GPIO2A5vccio3                                     | GRF_GPIO2A_IOMUX_H[6:4]=3'b1    |
|                   | I          | IO_LCDCd8m0_I2S08ch_sclkrx_CIFd7m1_SPI1mosi_GPIO3B4vccio4    | GRF_GPIO3B_IOMUX_H[2:0]=3'b11   |
| vip_data8         | I          | IO_CIFd8m0_GPIO2A6vccio3                                     | GRF_GPIO2A_IOMUX_H[10:8]=3'b1   |
|                   | I          | IO_LCDCd10m0_I2S08ch_sdo3_CIFd8m1_SPI1miso_GPIO3B6vccio4     | GRF_GPIO3B_IOMUX_H[10:8]=3'b11  |
| vip_data9         | I          | IO_CIFd9m0_GPIO2A7vccio3                                     | GRF_GPIO2A_IOMUX_H[14:12]=3'b1  |
|                   | I          | IO_LCDCd11m0_I2S08ch_sdo2_CIFd9m1_SPI1clk_GPIO3B7vccio4      | GRF_GPIO3B_IOMUX_H[14:12]=3'b11 |
| vip_data10        | I          | IO_I2C2scl_GPIO2B7vccio3                                     | GRF_GPIO2B_IOMUX_H[14:12]=3'b1  |
|                   | I          | IO_LCDCd18_PDMclk0m0_GPIO3C6vccio4                           | GRF_GPIO3C_IOMUX_H[10:8]=3'b11  |
| vip_data11        | I          | IO_I2C2sda_GPIO2C0vccio3                                     | GRF_GPIO2C_IOMUX_L[2:0]=3'b1    |
|                   | I          | IO_LCDCd19_PDMclk1_GPIO3C7vccio4                             | GRF_GPIO3C_IOMUX_H[14:12]=3'b11 |

## 6.6 Application Notes

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 VIP. The valid pixel number of scale result in FIFO can be known by read VIP\_SCL\_VALID\_NUM. The line number of last frame and the pixel number of last line can be also known by read the VIP\_LAST\_LINE and VIP\_LAST\_PIX.

## Chapter 7 Video Output Processor (VOP\_BIG)

### 7.1 Overview

Video Output Processor is a video process engine and a display interface from memory frame buffer to display device(LCD panel, MIPI, LVDS, RGB, ect). VOP is connected to an AHB bus through an AHB slave and 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.

#### 7.1.1 Features

The features listed below which may or may not be present in actual product, may be subject to the third party licensing requirements. Please contact Rockchip for actual product feature configurations and licensing requirements.

VOP\_BIG supports the following features:

- Display interface
  - Parallel RGB LCD Interface: 24-bit(RGB888),18-bit(RGB666), 16-bit(RGB565)
  - Display interface
    - ◆ Parallel Display interface
    - ◆ MIPI\_DSI\_TX
    - ◆ LVDS
  - Max output resolution
    - ◆ 1280x800 with CABC enable
    - ◆ 1920x1080 with CABC disable
- Display process
  - Background layer
    - ◆ programmable 24-bit color
  - Win0 layer
    - ◆ RGB888, ARGB888, RGB565, YCbCr422, YCbCr420, YCbCr444
    - ◆ 1/8 to 8 scaling-down and scaling-up engine
    - ◆ Support virtual display
    - ◆ 256 level alpha blending (pre-multiplied alpha support)
    - ◆ Transparency color key
    - ◆ YCbCr2RGB(rec601-mpeg/ rec601-jpeg/rec709)
    - ◆ RGB2YCbCr(BT601/BT709)
  - Win1 layer
    - ◆ RGB888, ARGB888, RGB565
    - ◆ Support virtual display
    - ◆ 256 level alpha blending (pre-multiplied alpha support)
    - ◆ Transparency color key
    - ◆ RGB2YCbCr(BT601/BT709)
    - ◆ Support AFBCD
  - Win2 layer
    - ◆ RGB888, ARGB888, RGB565
    - ◆ Support virtual display
    - ◆ 256 level alpha blending (pre-multiplied alpha support)
    - ◆ Transparency color key
    - ◆ RGB2YCbCr(BT601/BT709)
    - ◆ Support multi-region
      - HWC layer
        - ◆ Support 8BPP only
        - ◆ Size : 32x32 or 64x64
      - ◆ 256 level alpha blending (pre-multiplied alpha support)
      - ◆ RGB2YCbCr(BT601/BT709)
- Others
  - Win0 layer , Win1 layer and Win2 layer overlay exchangeable
  - Support RGB or YUV domain overlay

- BCSH(Brightness, Contrast, Saturation, Hue adjustment)
- BCSH:YCbCr2RGB(rec601-mpeg/ rec601-jpeg/rec709)
- BCSH:RGB2YCbCr(BT601/BT709)
- Support Gamma adjust for PAD
- Support CABC
- Support dither down allegro RGB888to666 RGB888to565 & dither down frc (configurable ) RGB888to666
- Blank and black display
- Standby mode
- Support QoS request for higher bus priority for win1/HWC
- Support NOC hurry for higher bus priority for win0
- Support all layers reg\_done separately

## 7.2 Block Diagram



Fig. 7-1 VOP Block Diagram

## 7.3 Function Description

### 7.3.1 Data Format

VOP master read the frame data from the frame buffer in the system memory. There are total 6 formats supported in three layers.

- Win0: RGB888, ARGB888, RGB565, YCbCr422\_SP, YCbCr420\_SP, YCbCr444\_SP
- Win1: RGB888, ARGB888, RGB565;  
AFBCD\_ARGB888, AFBCD\_RGB888, AFBCD\_RGB565
- Win2: RGB888, ARGB888, RGB565
- HWC: 8BPP



Fig. 7-2 VOP Frame Buffer Data Format



Fig. 7-3 VOP HWC Palette (8bpp)

### Data SWAP function

There are several swap options for different frame data formats..  
All the data swap types are in the following table.

Table 7-1 VOP Data Swap of Win0 and Win1

| Data-swap | RB swap | Alpha swap | Y-M8 swap | CbCr swap |
|-----------|---------|------------|-----------|-----------|
| Win0      | yes     | yes        | yes       | yes       |
| Win1      | yes     | yes        | No        | No        |

### 7.3.2 Data path

There are two data input path for VOP to get display layers' pixel data. One is internal DMA; the other is direction path interface.

#### 1.Internal DMA

Internal DMA can fetch the pixel data through AXI bus from system memory (DDR) for all the display layers. Data fetching is driven by display output requirement.



Fig. 7-4 VOP Internal DMA

### 7.3.3 Virtual display

Virtual display is supported in Win0 , Win1 , Win2. The active image is part of the virtual (original) image in frame buffer memory. The virtual width is indicated by setting WIN0/WIN1\_VIR\_STRIDE for different data format.

The virtual stride should be multiples of word (32-bit). That means dummy bytes in the end of virtual line if the real pixels are not 32-bit aligned.



Fig. 7-5 VOP Virtual Display Mode

### 7.3.4 Scaling

The scaling operation is the image resizing process of data transfer from the frame buffer memory to LCD panel or TV set.

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:

VOP\_WIN0\_SCL\_FACTOR\_Y/VOP\_WIN0\_SCL\_FACTOR\_CBR

Software calculates the scaling factor value using the following equations:

$$y\_rgb\_vertical\_factor = \left( \frac{VOP\_WIN0\_ACT\_INFO[31:16]}{VOP\_WIN0\_DSP\_INFO[31:16]} \right) \times 2^{12}$$

$$y\_rgb\_horizontal\_factor = \left( \frac{VOP\_WIN0\_ACT\_INFO[15:0]}{VOP\_WIN0\_DSP\_INFO[15:0]} \right) \times 2^{12}$$

$$yuv422\_yuv444\_Cbr\_vertical\_factor = \left( \frac{VOP\_WIN0\_ACT\_INFO[31:16]}{VOP\_WIN0\_DSP\_INFO[31:16]} \right) \times 2^{12}$$

$$yuv420\_Cbr\_vertical\_factor = \left( \frac{VOP\_WIN0\_ACT\_INFO[31:16]/2}{VOP\_WIN0\_DSP\_INFO[31:16]} \right) \times 2^{12}$$

$$yuv444\_Cbr\_horizontal\_factor = \left( \frac{VOP\_WIN0\_ACT\_INFO[15:0]}{VOP\_WIN0\_DSP\_INFO[15:0]} \right) \times 2^{12}$$

$$yuv422\_yuv420\_Cbr\_horizontal\_factor = \left( \frac{VOP\_WIN0\_ACT\_INFO[15:0]/2}{VOP\_WIN0\_DSP\_INFO[15:0]} \right) \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. 7-6 VOP Scaling Down Offset



Fig. 7-7 VOP Scaling Up Offset

Table 7-2 VOP Scaling Start Point Offset Registers

| scaling down/up start point offset  | Offset variable       | Register                |
|-------------------------------------|-----------------------|-------------------------|
| Win0 YRGB vertical scaling offset   | Win0_YRGB_vscl_offset | Win0_SCL_OFFSET [32:24] |
| Win0 YRGB horizontal scaling offset | Win0_YRGB_hscl_offset | Win0_SCL_OFFSET [23:16] |
| Win0 Cbr vertical scaling offset    | Win0_CBR_vscl_offset  | Win0_SCL_OFFSET [15:8]  |
| Win0 Cbr horizontal scaling offset  | Win0_CBR_hscl_offset  | Win0_SCL_OFFSET [7:0]   |

### 7.3.5 Overlay

#### 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 8BPP color palette layer, which is the top layer of the display screen. `dsp_hwc_data[23:0]` come from the HWC\_LUT, which input is a 8BPP data format and output is 24 bits `dsp_hwc_data`.

Win0, Win1 and Win2 are exchangeable by configure `sw_dsp_layer1_sel`, `sw_dsp_layer2_sel` and `sw_dsp_layer3_sel`.



Fig. 7-8 VOP Overlay Display

## 2. Transparency color key

There are specific registers(VOP\_WIN0\_COLOR\_KEY,VOP\_WIN1\_COLOR\_KEY) for Win0 ,Win1 and Win2 layer to configure the colorkey value.The two transparency color key can 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 as the transparent pixel. The pixel values with the source color key value are pixels not visible on the screen, and the under layer pixel values or solid background color are visible.

Transparency color key is done after the scaling module . So transparency color key can only be used in non-scaling mode.



Fig. 7-9 VOP Transparency Color Key

## 3. Alpha Blending

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 and Win1 normal mode only). In user-specified mode, the alpha value comes from the register (WINX\_ALPHA\_CTRL[11: 4]).

Pre-multiplied alpha are supported for per-pixel alpha in Win0 and Win 1, for Pre-multiplied alpha, the SRC data has already been multiplied with alpha value.



Fig. 7-10 VOP Alpha blending

## 4. RGB OVERLAY and YCbCr OVERLAY

VOP has a signal named sw\_overlay\_mode at DSP\_CTRL2[4] to decide overlay in RGB or YUV color space.

### RGB OVERLAY

All layers overlay in RGB color space. If win0 is YUV420/422/444, it can be converted to RGB888 by YUV2RGB use MPEG,JPEG and HDTV formula.

### YCbCr OVERLAY

All layers overlay in YCbCr color space .When win0/1 input picture format is RGB, it can be converted to YUV444 using BT601 or BT709.

Since HWC supports BPP8, we can directly use AYUV444 LUT instead of ARGB888 LUT.

### 7.3.6 BCSH

The BCSH block is used for brightness, contrast, saturation and hue adjustment to YCbCr

format image.

The following diagram shows the BCSH adjustment processing. All the factors should be set in the VOP registers.



Fig. 7-11 VOP BCSH Diagram

### 7.3.7 Gamma Correction

Gamma correction is necessary because most monitors don't have a linear relationship between the voltage and the brightness, which results in your scene looking like it has too much contrast and the light falling off from the source outward, happens too quickly. The result can also be problematic if you are going into a composition program.

You can correct this by "Gamma Correction", which allows you to display the images and textures on your computer in an accurate manner.

Your screen is not linear, in that it displays the brightness unevenly. As a result, the image looks to be more high contrast than it should, you end up adding more lights or turning up the intensity, or you don't use the lighting in a realistic way that matches well with live action scenes. It also creates problems for you if you use compositing software.

It consumes 256x8bit LUT for each channel. You can write gamma correction LUT through register "DSP\_LUT\_ADDR" one by one after set `dsp_lut_en = 0`.



3x256x8-bit LUTs

Fig. 7-12 VOP Gamma LUTs

### 7.3.8 Replication and dither down

#### 1 Replication (dither up)

If the interface data bus is wider than the pixel format 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. 7-13 VOP Replication

Dithering is used to improve the quality of display the pixel data in a lower color depth on the LCD panel. The Dithering algorithm is based on the (x,y) pixel position, the value of removed bits and frame counter.

## 2 Dither down

Here we support three kinds of dithering arithmetic. RGB888 to RGB666 has two ways, one is allegro, the other is FRC. RGB888 to RGB565 has only one arithmetic, which is allegro. When Dithering is not enabled, the MSBs of the pixel color components are output on the interface data bus if the interface data bus is smaller than the pixel format size.



Fig. 7-14 vop dithering

The following figure is the recommended pattern picture in vop, you can config different value of reg 0x170~0x184, to change the pattern picture.(default value is recommended values below)

## 7.3.9 CABC

CABC(Content Adaptive Backlight Control) is used to increase the contrast of such LCD-screens the backlight can be (globally) dimmed when the image to be displayed is dark (i.e. not comprising high intensity image data) while the image data is numerically corrected and adapted to the reduced backlight intensity.

There are 3x7 Gaussian filter tables in reg 0x1d0~0x1e4.

default value as follow:

0x1c8 : 0x15110903

0x1cc : 0x00030911

0x1d0 : 0x1a150b04

0x1d4 : 0x00040b15

0x1d8 : 0x15110903

0x1dc : 0x00030911

program guide:

step1: Config the panel total pixel number to register CABC\_CTRL0 [26:4],and config the calc pixel num to register CABC\_CTRL1 [26:4].

(typical: calc\_pixel\_num / total\_pixel\_num = 95% ~98%).

step2: Config pwm\_config\_mode ,cabc\_handle\_en to register CABC\_CTRL0 .

step3: Config CABC\_CTRL2 and CABC\_CTRL3 register.

step4: write pwm gamma lut to CABC\_GAMMA\_LUT\_ADDR (vop\_base\_addr + 0x1800), typical gamma value = 2.2(typical)  
step5: Config cabc\_lut\_en and cabc\_en to register CABC\_CTRL1 [0] and CABC\_CTRL0 [0].  
step6: Config done.

### 7.3.10 AFBCD

This compression format is designed to be used for textures and frame buffers. It has been optimized to decrease external bandwidth as well as being random access and decodable at line speed for the texture cache.

The AFBCD has the following feature/limitations:

- Lossless compression
- Only WIN1 support AFBCD
- Support AFBC\_ARGB8888, AFBC\_RGB888,AFBC\_RGB565
- Only support half mode
- Don't support split mode
- Support x\_offset and y\_offset in pixel
- Support header virtual stride
- AFBCD\_PIC\_PTR must be 128-bit alignment

### 7.3.11 Multi-region display

The multi-region display of win2 has the following limitations:

- There is only one region in the same line
- There is not overlap region between different regions
- When display one region , region0 must be enable .When display two regions , region0 and region1 must be enable , and so on

Multi-region display application is shown as follows :



Fig. 7-15 Limitations of multi-region display of win2



Fig. 7-16 Correct application of multi-region display of win2

## 7.4 Register Description

### 7.4.1 Internal Address Mapping

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

### 7.4.2 Registers Summary

| Name                        | Offset | Size | Reset Value | Description                               |
|-----------------------------|--------|------|-------------|-------------------------------------------|
| VOP_BIG_REG_CFG_DONE        | 0x0000 | W    | 0x00000000  | Register config done flag                 |
| VOP_BIG_VERSION             | 0x0004 | W    | 0x00000000  | Version for vop                           |
| VOP_BIG_DSP_BG              | 0x0008 | W    | 0x00000000  | Display control register                  |
| VOP_BIG MCU                 | 0x000c | W    | 0x00000000  | MCU control register                      |
| VOP_BIG_SYS_CTRL0           | 0x0010 | W    | 0x00000000  | System control register                   |
| VOP_BIG_SYS_CTRL1           | 0x0014 | W    | 0x00000000  | System control register                   |
| VOP_BIG_SYS_CTRL2           | 0x0018 | W    | 0x00006000  | System control register                   |
| VOP_BIG_POST_LB_CTRL        | 0x001c | W    | 0x00000000  | Post lb control register                  |
| VOP_BIG_DSP_CTRL0           | 0x0020 | W    | 0x00000101  | Display register                          |
| VOP_BIG_DSP_CTRL1           | 0x0024 | W    | 0x00000000  | Display register                          |
| VOP_BIG_DSP_CTRL2           | 0x0028 | W    | 0x00004000  | Display register                          |
| VOP_BIG_VOP_STATUS          | 0x002c | W    | 0x00000000  | Some vop module status                    |
| VOP_BIG_LINE_FLAG           | 0x0030 | W    | 0x00000000  | Line flag config register                 |
| VOP_BIG_INTR_EN             | 0x0034 | W    | 0x00000000  | Interrupt enable register                 |
| VOP_BIG_INTR_CLEAR          | 0x0038 | W    | 0x00000000  | Interrupt clear register                  |
| VOP_BIG_INTR_STATUS         | 0x003c | W    | 0x00000000  | Interrupt raw status and interrupt status |
| VOP_BIG_WINO_CTRL0          | 0x0050 | W    | 0x00000000  | Win0 ctrl register                        |
| VOP_BIG_WINO_CTRL1          | 0x0054 | W    | 0x00021220  | Win0 ctrl register                        |
| VOP_BIG_WINO_COLORKEY       | 0x0058 | W    | 0x00000000  | Win0 color key register                   |
| VOP_BIG_WINO_VIR            | 0x005c | W    | 0x01400140  | Win0 virtual stride                       |
| VOP_BIG_WINO_YRGB_MST0      | 0x0060 | W    | 0x00000000  | Win0 YRGB memory start address 0          |
| VOP_BIG_WINO_CBR_MST0       | 0x0064 | W    | 0x00000000  | Win0 Cbr memory start address 0           |
| VOP_BIG_WINO_ACT_INFO       | 0x0068 | W    | 0x00ef013f  | Win0 active window width/height           |
| VOP_BIG_WINO_DSP_INFO       | 0x006c | W    | 0x00ef013f  | Win0 display width/height on panel        |
| VOP_BIG_WINO_DSP_ST         | 0x0070 | W    | 0x0000000a  | Win0 display start point on panel         |
| VOP_BIG_WINO_SCL_FACT0_YRGB | 0x0074 | W    | 0x10001000  | Win0 YRGB scaling factor                  |
| VOP_BIG_WINO_SCL_FACT0_CBR  | 0x0078 | W    | 0x10001000  | Win0 CBR scaling factor                   |

| Name                       | Offset | Size | Reset Value | Description                                                                  |
|----------------------------|--------|------|-------------|------------------------------------------------------------------------------|
| VOP_BIG_WIN0_SCL_OFF_SET   | 0x007c | W    | 0x00000000  | Win0 scaling start point offset                                              |
| VOP_BIG_WIN0_ALPHA_CTRL    | 0x0080 | W    | 0x00000000  | Blending control register                                                    |
| VOP_BIG_WIN1_CTRL0         | 0x0090 | W    | 0x00000000  | Win1 ctrl register                                                           |
| VOP_BIG_WIN1_CTRL1         | 0x0094 | W    | 0x00000500  | Win1 ctrl register                                                           |
| VOP_BIG_WIN1_VIR           | 0x0098 | W    | 0x00000000  | Win1 virtual stride                                                          |
| VOP_BIG_WIN1_MST           | 0x00a0 | W    | 0x00000000  | Win1 memory start address                                                    |
| VOP_BIG_WIN1_DSP_INF_O     | 0x00a4 | W    | 0x00ef013f  | Win1 display width/height on panel                                           |
| VOP_BIG_WIN1_DSP_ST        | 0x00a8 | W    | 0x0000000a  | Win1 display start point on panel                                            |
| VOP_BIG_WIN1_COLOR_KEY     | 0x00ac | W    | 0x00000000  | Win1 color key register                                                      |
| VOP_BIG_WIN1_ALPHA_CTRL    | 0x00bc | W    | 0x00000000  | Blending control register                                                    |
| VOP_BIG_HWC_CTRL0          | 0x00e0 | W    | 0x00000000  | Hwc ctrl register                                                            |
| VOP_BIG_HWC_MST            | 0x00e8 | W    | 0x00000000  | Hwc memory start address                                                     |
| VOP_BIG_HWC_DSP_ST         | 0x00ec | W    | 0x00000000  | Hwc display start point on panel                                             |
| VOP_BIG_HWC_ALPHA_CTRL     | 0x00f0 | W    | 0x00000000  | Blending control register                                                    |
| VOP_BIG_DSP_HTOTAL_HS_END  | 0x0100 | W    | 0x014a000a  | Panel scanning horizontal width and hsync pulse end point                    |
| VOP_BIG_DSP_HACT_ST_END    | 0x0104 | W    | 0x000a0000  | Panel active horizontal scanning start point and end point                   |
| VOP_BIG_DSP_VTOTAL_VS_END  | 0x0108 | W    | 0x00fa000a  | Panel scanning vertical height and vsync pulse end point                     |
| VOP_BIG_DSP_VACT_ST_END    | 0x010c | W    | 0x000a00fa  | Panel active vertical scanning start point and end point                     |
| VOP_BIG_DSP_VS_ST_END_F1   | 0x0110 | W    | 0x00000000  | Vertical scanning start point and vsync pulse end point of even file         |
| VOP_BIG_DSP_VACT_ST_END_F1 | 0x0114 | W    | 0x00000000  | Vertical scanning active start point and end point of even filed in interlac |
| VOP_BIG_BCSH_CTRL          | 0x0160 | W    | 0x00000000  | Brightness/Contrast enhancement/Saturation/Hue contrl                        |
| VOP_BIG_BCSH_COL_BAR       | 0x0164 | W    | 0x00000000  | vedio mode equals 2,then output color bar yuv 24bits value                   |
| VOP_BIG_BCSH_BCS           | 0x0168 | W    | 0x00000000  | Brightness/Contrast enhancement/Saturation                                   |
| VOP_BIG_BCSH_H             | 0x016c | W    | 0x00000000  | Hue                                                                          |
| VOP_BIG_FRC_LOWER01_0      | 0x0170 | W    | 0x12844821  | Frc algorithm configuration register                                         |

| <b>Name</b>                | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>                       |
|----------------------------|---------------|-------------|--------------------|------------------------------------------|
| VOP_BIG_FRC_LOWER01_1      | 0x0174        | W           | 0x21488412         | Frc algorithm configuration register     |
| VOP_BIG_FRC_LOWER10_0      | 0x0178        | W           | 0xa55a9696         | Frc algorithm configuration register     |
| VOP_BIG_FRC_LOWER10_1      | 0x017c        | W           | 0x5aa56969         | Frc algorithm configuration register     |
| VOP_BIG_FRC_LOWER11_0      | 0x0180        | W           | 0xdeb77bed         | Frc algorithm configuration register     |
| VOP_BIG_FRC_LOWER11_1      | 0x0184        | W           | 0xed7bb7de         | Frc algorithm configuration register     |
| VOP_BIG_MCU_RW_BYPASS_PORT | 0x018c        | W           | 0x00000000         | MCU panel write data                     |
| VOP_BIG_DBG_REG_SCAN_LINE  | 0x0190        | W           | 0x00000000         | Current line number of dsp timing        |
| VOP_BIG_WIN2_CTRL0         | 0x0190        | W           | 0x00000000         | win2 ctrl register                       |
| VOP_BIG_WIN2_CTRL1         | 0x0194        | W           | 0x003a0000         | win2 ctrl register                       |
| VOP_BIG_WIN2_VIRO_1        | 0x0198        | W           | 0x01400140         | Win2 virtual stride0 and virtaul stride1 |
| VOP_BIG_WIN2_VIR2_3        | 0x019c        | W           | 0x01400140         | Win2 virtual stride2 and virtaul stride3 |
| VOP_BIG_WIN2_MST0          | 0x01a0        | W           | 0x00000000         | Win2 memory start address0               |
| VOP_BIG_WIN2_DSP_INF_00    | 0x01a4        | W           | 0x00ef013f         | Win2 display width0/height0 on panel     |
| VOP_BIG_WIN2_DSP_ST0       | 0x01a8        | W           | 0x000a000a         | Win2 display start point0 on panel       |
| VOP_BIG_WIN2_COLOR_KEY     | 0x01ac        | W           | 0x00000000         | Win2 color key register                  |
| VOP_BIG_WIN2_MST1          | 0x01b0        | W           | 0x00000000         | Win2 memory start address1               |
| VOP_BIG_WIN2_DSP_INF_01    | 0x01b4        | W           | 0x00ef013f         | Win2 display width1/height1 on panel     |
| VOP_BIG_WIN2_DSP_ST1       | 0x01b8        | W           | 0x000a000a         | Win2 display start point1 on panel       |
| VOP_BIG_WIN2_ALPHA_CONTROL | 0x01bc        | W           | 0x00000000         | Win2 alpha source control register       |
| VOP_BIG_WIN2_MST2          | 0x01c0        | W           | 0x00000000         | Win2 memory start address2               |
| VOP_BIG_WIN2_DSP_INF_02    | 0x01c4        | W           | 0x00ef013f         | Win2 display width2/height2 on panel     |
| VOP_BIG_WIN2_DSP_ST2       | 0x01c8        | W           | 0x000a000a         | Win2 display start point2 on panel       |
| VOP_BIG_WIN2_MST3          | 0x01d0        | W           | 0x00000000         | Win2 memory start address3               |
| VOP_BIG_WIN2_DSP_INF_03    | 0x01d4        | W           | 0x00ef013f         | Win2 display width3/height3 on panel     |
| VOP_BIG_WIN2_DSP_ST3       | 0x01d8        | W           | 0x000a000a         | Win2 display start point3 on panel       |
| VOP_BIG_BLANKING_VALUE     | 0x01f4        | W           | 0x00000000         | The value of vsync blanking              |

| Name                       | Offset | Size | Reset Value | Description                                                     |
|----------------------------|--------|------|-------------|-----------------------------------------------------------------|
| VOP_BIG_FLAG_REG_FRM_VALID | 0x01f8 | W    | 0x00000000  | Flag reg value after frame valid                                |
| VOP_BIG_FLAG_REG           | 0x01fc | W    | 0x00000000  | Flag reg value before frame valid                               |
| VOP_BIG_CABC_CTRL0         | 0x0200 | W    | 0x00000000  | Content Adaptive Backlight Control register0                    |
| VOP_BIG_CABC_CTRL1         | 0x0204 | W    | 0x00000000  | Content Adaptive Backlight Control register1                    |
| VOP_BIG_CABC_CTRL2         | 0x0208 | W    | 0x00000000  | Content Adaptive Backlight Control register2                    |
| VOP_BIG_CABC_CTRL3         | 0x020c | W    | 0x00000000  | Content Adaptive Backlight Control register3                    |
| VOP_BIG_CABC_GAUSS_LINE0_0 | 0x0210 | W    | 0x00000000  | CABC gauss line config register                                 |
| VOP_BIG_CABC_GAUSS_LINE0_1 | 0x0214 | W    | 0x00000000  | CABC gauss line config register                                 |
| VOP_BIG_CABC_GAUSS_LINE1_0 | 0x0218 | W    | 0x00000000  | CABC gauss line config register                                 |
| VOP_BIG_CABC_GAUSS_LINE1_1 | 0x021c | W    | 0x00000000  | CABC gauss line config register                                 |
| VOP_BIG_CABC_GAUSS_LINE2_0 | 0x0220 | W    | 0x00000000  | CABC gauss line config register                                 |
| VOP_BIG_CABC_GAUSS_LINE2_1 | 0x0224 | W    | 0x00000000  | CABC gauss line config register                                 |
| VOP_BIG_PWM_CTRL           | 0x0230 | W    | 0x00000000  | PWM Control Register , The register provides the control of PWM |
| VOP_BIG_PWM_PERIOD_HPR     | 0x0234 | W    | 0x00000000  | PWM Period Register/High Polarity Capture Register              |
| VOP_BIG_PWM_DUTY_LP_R      | 0x0238 | W    | 0x00000000  | PWM Duty Register/Low Polarity Capture Register                 |
| VOP_BIG_PWM_CNT            | 0x023c | W    | 0x00000000  | PWM Counter Register                                            |
| VOP_BIG_AFBCD_CTRL         | 0x0240 | W    | 0x00000000  | AFBCD control register                                          |
| VOP_BIG_AFBCD_HDR_PTR      | 0x0244 | W    | 0x00000000  | AFBC header memory start address                                |
| VOP_BIG_AFBCD_PIC_SIZE     | 0x0248 | W    | 0x00000000  | AFBCD picture size                                              |
| VOP_BIG_AFBCD_PIC_OFFSET   | 0x024c | W    | 0x00000000  | AFBCD picture offset                                            |
| VOP_BIG_AFBCD_AXI_CTRL     | 0x0250 | W    | 0x00000000  | AFBCD axi control register                                      |
| VOP_BIG_AFBCD_DBG0         | 0x0254 | W    | 0x00000000  | AFBCD debug register                                            |
| VOP_BIG_CABC_LUT_ADDRESS   | 0x0400 | W    | 0x00000000  | note: used for CABC , base address: 0x400 -- 0x5FF              |

| Name                        | Offset | Size | Reset Value | Description                                                                      |
|-----------------------------|--------|------|-------------|----------------------------------------------------------------------------------|
| VOP_BIG_HWC_LUT_ADD_R       | 0x0600 | W    | 0x00000000  | note: used for HWC BPP format , base address: 0x600 -- 0x9FF                     |
| VOP_BIG_GAMMA_LUT_ADDR      | 0x0a00 | W    | 0x00000000  | note: SIZE: 24X256 used for panel GAMMA adjustment, base address: 0xa00 -- 0xdff |
| VOP_BIG_MMU_DTE_ADDR        | 0x0f00 | W    | 0x00000000  | MMU current page Table address                                                   |
| VOP_BIG_MMU_STATUS          | 0x0f04 | W    | 0x00000000  | MMU status register                                                              |
| VOP_BIG_MMU_COMMAND         | 0x0f08 | W    | 0x00000000  | MMU command register                                                             |
| VOP_BIG_MMU_PAGE_FAULT_ADDR | 0x0f0c | W    | 0x00000000  | MMU logical address of last page fault                                           |
| VOP_BIG_MMU_ZAP_ONE_LINE    | 0x0f10 | W    | 0x00000000  | MMU Zap cache line register                                                      |
| VOP_BIG_MMU_INT_RAW_STAT    | 0x0f14 | W    | 0x00000000  | MMU raw interrupt status register                                                |
| VOP_BIG_MMU_INT_CLEA_R      | 0x0f18 | W    | 0x00000000  | MMU raw interrupt status register                                                |
| VOP_BIG_MMU_INT_MASK        | 0x0f1c | W    | 0x00000000  | MMU raw interrupt status register                                                |
| VOP_BIG_MMU_INT_STATUS      | 0x0f20 | W    | 0x00000000  | MMU raw interrupt status register                                                |
| VOP_BIG_MMU_AUTO_GATING     | 0x0f24 | W    | 0x00000000  | mmu auto gating                                                                  |
| VOP_BIG_MMU_CFG_DONE        | 0x0f28 | W    | 0x00000000  | mmu config done reg                                                              |

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

### 7.4.3 Detail Register Description

#### VOP\_BIG\_REG\_CFG\_DONE

Address: Operational Base + offset (0x0000)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_mask<br>When every bit HIGH, enable the writing corresponding bit<br>When every bit LOW, don't care the writing corresponding bit                                                                                                                                                                                                                        |
| 15:6       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                       |
| 5          | RW          | 0x0                | reg_load_sys_en<br>In the first setting of the register, the new value was saved into the mirror register.<br>When all the system register config finish(all reg except win0 win1 hwc iep), 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                  |
| 4          | RW          | 0x0                | reg_load_iep_en<br>In the first setting of the register, the new value was saved into the mirror register.<br>When all the iep register config finish(only 2 signals direct_path_en,direct_path_layer_sel ), 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 |
| 3          | RW          | 0x0                | reg_load_hwc_en<br>In the first setting of the register, the new value was saved into the mirror register.<br>When all the hwc 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                                                       |
| 2          | RW          | 0x0                | reg_load_win1_en<br>In the first setting of the register, the new value was saved into the mirror register.<br>When all the win1 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                                                     |
| 1          | RW          | 0x0                | reg_load_win0_en<br>In the first setting of the register, the new value was saved into the mirror register.<br>When all the win0 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                                                     |
| 0          | WO          | 0x0                | reg_load_global_en<br>In the first setting of the register, the new value was saved into the mirror register.<br>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                                                        |

**VOP BIG VERSION**

Address: Operational Base + offset (0x0004)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                               |
|------------|-------------|--------------------|--------------------------------------------------|
| 31:24      | RO          | 0x00               | major<br>used for IP structure                   |
| 23:16      | RO          | 0x00               | minor<br>big feature change under same structure |
| 15:0       | RO          | 0x0000             | build<br>rtl current svn number                  |

**VOP\_BIG\_DSP\_BG**

Address: Operational Base + offset (0x0008)

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

**VOP\_BIG MCU**

Address: Operational Base + offset (0x000c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------|
| 31         | RW          | 0x0                | mcu_type<br>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<br>1'b0 : command<br>1'b1 : data                                |
| 28         | RW          | 0x0                | mcu_frame_st<br>Write"1" : MCU HOLD Mode Frame Start<br>Read : MCU/LCDC standby HOLD status |
| 27         | RW          | 0x0                | mcu_hold_mode<br>MCU HOLD Mode Select                                                       |
| 26         | RW          | 0x0                | mcu_clk_sel<br>1'b1 : MCU BYPASS sync with DCLK<br>1'b0 : MCU BYPASS sync with HCLK         |
| 25:20      | RW          | 0x00               | mcu_rw_pend<br>MCU_RW signal end point (0-63)                                               |
| 19:16      | RW          | 0x0                | mcu_rw_pst<br>MCU_RW signal start point (0-15)                                              |
| 15:10      | RW          | 0x00               | mcu_cs_pend<br>MCU_CS signal end point (0-63)                                               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 9:6        | RW          | 0x0                | mcu_cs_pst<br>MCU_CS signal start point (0-15)           |
| 5:0        | RW          | 0x00               | mcu_pix_total<br>MCU LCD Interface writing period (1-63) |

**VOP BIG SYS CTRL0**

Address: Operational Base + offset (0x0010)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>   |
|------------|-------------|--------------------|----------------------|
| 31:0       | RW          | 0x00000000         | reserved<br>Reserved |

**VOP BIG SYS CTRL1**

Address: Operational Base + offset (0x0014)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                      |
|------------|-------------|--------------------|---------------------------------------------------------|
| 31:21      | RO          | 0x0                | reserved                                                |
| 20:16      | RW          | 0x00               | sw_axi_max_outstand_num<br>axi max outstanding number   |
| 15:13      | RO          | 0x0                | reserved                                                |
| 12         | RW          | 0x0                | sw_axi_max_outstand_en<br>1'b0: disable<br>1'b1: enable |
| 11:8       | RW          | 0x0                | sw_noc_hurry_threshold<br>noc hurry threshold           |
| 7          | RO          | 0x0                | reserved                                                |
| 6:5        | RW          | 0x0                | sw_noc_hurry_value<br>noc hurry value                   |
| 4          | RW          | 0x0                | sw_noc_hurry_en<br>1'b0: disable<br>1'b1: enable        |
| 3          | RO          | 0x0                | reserved                                                |
| 2:1        | RW          | 0x0                | sw_noc_qos_value<br>noc qos value                       |
| 0          | RW          | 0x0                | sw_noc_qos_en<br>1'b0: disable<br>1'b1: enable          |

**VOP BIG SYS CTRL2**

Address: Operational Base + offset (0x0018)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                               |
|------------|-------------|--------------------|------------------------------------------------------------------|
| 31:16      | RO          | 0x0                | reserved                                                         |
| 15         | RW          | 0x0                | dcf_idle_en<br>1'b0 : dcf idle disable<br>1'b1 : dcf idle enable |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| 14         | RW          | 0x1                | fs_addr_mask_en<br>1'b0: disable<br>1'b1: enable                                                                                                   |
| 13         | RW          | 0x1                | imd_global_regdone_en<br>1'b0: DISABLE<br>1'b1: ENALBE                                                                                             |
| 12         | RW          | 0x0                | imd_dsp_timing_imd<br>1'b0: timing reg valid immediatly<br>1'b1: timing reg valid after frame start                                                |
| 11         | RW          | 0x0                | imd_edpi_frm_st<br>wms_fs                                                                                                                          |
| 10         | RW          | 0x0                | imd_edpi_ctrl_mode<br>1'b0 : wms is enable by te and wms_fs<br>1'b1 : wms is enable by te only                                                     |
| 9          | RW          | 0x0                | imd_edpi_te_en<br>1'b0 : disable TE<br>1'b1 : enable TE                                                                                            |
| 8          | RO          | 0x0                | reserved                                                                                                                                           |
| 7          | RW          | 0x0                | sw_io_pad_clk_sel<br>1'b0: normal dclk out<br>1'b1: gating dclk out                                                                                |
| 6          | RW          | 0x0                | imd_dsp_data_out_mode<br>1'b0: normal output mode<br>1'b1: output 24'b0                                                                            |
| 5          | RO          | 0x0                | reserved                                                                                                                                           |
| 4          | RW          | 0x0                | imd_yuv_clip<br>1'b0: disable, YCbCr no clip<br>1'b1: enable, YCbCr clip before YCbCr2RGB<br>*Y clip: 16~235, CBCR clip: 16~239                    |
| 3          | RW          | 0x0                | imd_dsp_out_zero<br>1'b0 : normal output<br>1'b1 : output '0' means:hsync,vsync,den =000                                                           |
| 2          | RW          | 0x0                | imd_vop_dma_stop<br>1'b0: disable<br>1'b1: enable<br>* If DMA is working, the stop mode would not be active until current bus transfer is finished |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1          | RW          | 0x0                | <p>imd_vop_standby_en<br/>Writing "1" to turn VOP into standby mode, All the layer would disable and the data transfer from frame buffer memory would stop at the end of current frame.<br/>The output would be blank.</p> <p>When writing "0" to this bit, standby mode would disable and the VOP go back to work immediately.</p> <p>1'b0: disable<br/>1'b1: enable<br/>* Black display is recommended before setting standby mode enable</p> |
| 0          | RW          | 0x0                | <p>imd_auto_gating_en<br/>1'b0: disable<br/>1'b1: enable</p>                                                                                                                                                                                                                                                                                                                                                                                    |

**VOP BIG POST LB CTRL**

Address: Operational Base + offset (0x001c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                               |
|------------|-------------|--------------------|------------------------------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                                         |
| 7:4        | RW          | 0x0                | post_lb_almost_empty_threshold<br>post lb almost empty threshold |
| 3:0        | RW          | 0x0                | post_lb_almost_full_threshold<br>post lb almost full threshold   |

**VOP BIG DSP CTRL0**

Address: Operational Base + offset (0x0020)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:29      | RO          | 0x0                | reserved                                                                                                                           |
| 28         | RW          | 0x0                | mipi_den_pol<br>1'b0: positive<br>1'b1: negative<br>when this channel dclk_en = 0, this signal used for contrl corresponding bit   |
| 27         | RW          | 0x0                | mipi_vsync_pol<br>1'b0: negative<br>1'b1: positive<br>when this channel dclk_en = 0, this signal used for contrl corresponding bit |
| 26         | RW          | 0x0                | mipi_hsync_pol<br>1'b0: negative<br>1'b1: positive<br>when this channel dclk_en = 0, this signal used for contrl corresponding bit |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 25         | RW          | 0x0                | mipi_dclk_pol<br>1'b0:mipi dclk inv disable<br>1'b1:mipi dclk inv enable                                                           |
| 24         | RW          | 0x0                | mipi_dclk_en<br>1'b0:mipi dclk disable<br>1'b1:mipi dclk enable                                                                    |
| 23:15      | RO          | 0x0                | reserved                                                                                                                           |
| 14         | RW          | 0x0                | sw_hdmi_clk_i_sel<br>1'b0: select dclk to hdmi io<br>1'b1: select dclk_core to hdmi io                                             |
| 13         | RW          | 0x0                | sw_core_clk_sel<br>1'b0: select dclk sclk<br>1'b1: select dclk_div sclk_div                                                        |
| 12         | RW          | 0x0                | hdmi_den_pol<br>1'b0: positive<br>1'b1: negative<br>when this channel dclk_en = 0, this signal used for contrl corresponding bit   |
| 11         | RW          | 0x0                | hdmi_vsync_pol<br>1'b0: negative<br>1'b1: positive<br>when this channel dclk_en = 0, this signal used for contrl corresponding bit |
| 10         | RW          | 0x0                | hdmi_hsync_pol<br>1'b0: negative<br>1'b1: positive<br>when this channel dclk_en = 0, this signal used for contrl corresponding bit |
| 9          | RW          | 0x0                | hdmi_dclk_pol<br>1'b0:hdmi dclk inv disable<br>1'b1:hdmi dclk inv enable                                                           |
| 8          | RW          | 0x1                | hdmi_dclk_en<br>1'b0:hdmi dclk disable<br>1'b1:hdmi dclk enable                                                                    |
| 7:5        | RO          | 0x0                | reserved                                                                                                                           |
| 4          | RW          | 0x0                | rgb_den_pol<br>1'b0: positive<br>1'b1: negative<br>when this channel dclk_en = 0, this signal used for contrl corresponding bit    |
| 3          | RW          | 0x0                | rgb_vsync_pol<br>1'b0: negative<br>1'b1: positive<br>when this channel dclk_en = 0, this signal used for contrl corresponding bit  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 2          | RW          | 0x0                | rgb_hsync_pol<br>1'b0: negative<br>1'b1: positive<br>when this channel dclk_en = 0, this signal used for contrl corresponding bit |
| 1          | RW          | 0x0                | rgb_dclk_pol<br>1'b0:rgb dclk inv disable<br>1'b1:rgb dclk inv enable                                                             |
| 0          | RW          | 0x1                | rgb_dclk_en<br>1'b0:rgb dclk disable<br>1'b1:rgb dclk enable                                                                      |

**VOP\_BIG\_DSP\_CTRL1**

Address: Operational Base + offset (0x0024)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>   |
|------------|-------------|--------------------|----------------------|
| 31:0       | RW          | 0x00000000         | reserved<br>Reserved |

**VOP\_BIG\_DSP\_CTRL2**

Address: Operational Base + offset (0x0028)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                                                             |
| 27:26      | RW          | 0x0                | dsp_layer3_sel<br>Layer3 select<br>2'b00 : select WIN0<br>2'b01 : select WIN1<br>2'b10 : select WIN2 |
| 25:24      | RW          | 0x0                | dsp_layer2_sel<br>Layer2 select<br>2'b00 : select WIN0<br>2'b01 : select WIN1<br>2'b10 : select WIN2 |
| 23:22      | RW          | 0x0                | dsp_layer1_sel<br>Layer1 select<br>2'b00 : select WIN0<br>2'b01 : select WIN1<br>2'b10 : select WIN2 |
| 21         | RO          | 0x0                | reserved                                                                                             |
| 20         | RW          | 0x0                | post_lb_mode<br>1'b0 : 1920x3<br>1'b1 : 1280x4                                                       |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 19:16      | RW          | 0x0                | <p>dsp_out_mode<br/>           4'b0000: Parallel 24-bit RGB888 output      R[7:0],G[7:0],B[7:0]<br/>           4'b0001: Parallel 18-bit RGB666 output<br/>           6'b0,R[5:0],G[5:0],B[5:0]<br/>           4'b0010: Parallel 16-bit RGB565 output<br/>           8'b0,R[4:0],G[5:0],B[4:0]<br/>           Others: Reserved</p> |
| 15         | RW          | 0x0                | <p>dsp_black_en<br/>           When this bit enable, the pixel data output is all black<br/>           (0x000000)</p>                                                                                                                                                                                                             |
| 14         | RW          | 0x1                | <p>dsp_blank_en<br/>           When this bit enable, the hsync/vsync/den output is blank. means:hsync,vsync,den =110</p>                                                                                                                                                                                                          |
| 13         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                          |
| 12         | RW          | 0x0                | <p>dsp_rg_swap<br/>           1'b0: RGB<br/>           1'b1: GRB</p>                                                                                                                                                                                                                                                              |
| 11         | RW          | 0x0                | <p>dsp_rb_swap<br/>           1'b0: RGB<br/>           1'b1: BGR</p>                                                                                                                                                                                                                                                              |
| 10         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                          |
| 9          | RW          | 0x0                | <p>dsp_bg_swap<br/>           1'b0: RGB<br/>           1'b1: RBG</p>                                                                                                                                                                                                                                                              |
| 8          | RW          | 0x0                | <p>dither_down<br/>           1'b0: disable<br/>           1'b1: enable</p>                                                                                                                                                                                                                                                       |
| 7          | RW          | 0x0                | <p>dither_down_sel<br/>           1'b0: allegro<br/>           1'b1: FRC</p>                                                                                                                                                                                                                                                      |
| 6          | RW          | 0x0                | <p>dither_down_mode<br/>           1'b0: RGB888 to RGB565<br/>           1'b1: RGB888 to RGB666</p>                                                                                                                                                                                                                               |
| 5          | RW          | 0x0                | <p>dsp_lut_en<br/>           1'b0: disable<br/>           1'b1: enable<br/>           *This bit should be "0" when CPU updates the LUT, and should be "1" when Display LUT mode enable</p>                                                                                                                                        |
| 4          | RW          | 0x0                | <p>sw_overlay_mode<br/>           1'b0: overlay in rgb domain<br/>           1'b1: overlay in yuv domain</p>                                                                                                                                                                                                                      |
| 3          | RW          | 0x0                | <p>dsp_win0_top<br/>           1'b0: win1 on the top of win0<br/>           1'b1: win0 on the top of win1</p>                                                                                                                                                                                                                     |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2          | RW          | 0x0                | dither_up<br>1'b0: disable<br>1'b1: enable                                                                                                                                                      |
| 1          | RW          | 0x0                | interlace_field_pol<br>1'b0: normal<br>1'b1: invert                                                                                                                                             |
| 0          | RW          | 0x0                | dsp_interlace<br>1'b0: disable<br>1'b1: enable<br>*This mode is related to the TVE output, the display timing of odd field must be set correctly.<br>(vop_dsp_vs_st_end_f1/vop_dsp_vact_end_f1) |

**VOP BIG VOP STATUS**

Address: Operational Base + offset (0x002c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------|
| 31:14      | RO          | 0x0                | reserved                                                                |
| 13         | RW          | 0x0                | intr_post_lb_almost_emtpy_mux<br>1'b0 : interrupt0<br>1'b1 : interrupt1 |
| 12         | RW          | 0x0                | intr_post_lb_almost_full_mux<br>1'b0 : interrupt0<br>1'b1 : interrupt1  |
| 11         | RO          | 0x0                | reserved                                                                |
| 10         | RW          | 0x0                | intr_line_flag1_mux<br>1'b0 : interrupt0<br>1'b1 : interrupt1           |
| 9          | RW          | 0x0                | intr_line_flag0_mux<br>1'b0 : interrupt0<br>1'b1 : interrupt1           |
| 8          | RW          | 0x0                | intr_dma_finish_mux<br>1'b0 : interrupt0<br>1'b1 : interrupt1           |
| 7:5        | RO          | 0x0                | reserved                                                                |
| 4          | RO          | 0x0                | dma_stop_valid<br>vop dma stop status                                   |
| 3          | RO          | 0x0                | reserved                                                                |
| 2          | RO          | 0x0                | int_raw_dma_finish<br>dma finish raw singal<br>1:finish<br>0:not finish |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------|
| 1          | RO          | 0x0                | idle_mmu_ff1<br>mmu idle status<br>1:idle<br>0:busy                   |
| 0          | RO          | 0x0                | dsp_blinking_en_async_aff2<br>1:blinking enable<br>0:blinking disable |

**VOP BIG LINE FLAG**

Address: Operational Base + offset (0x0030)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                                                                      |
| 27:16      | RW          | 0x000              | dsp_line_flag1_num<br>The display line number when the flag interrupt 1 occur, the range is (0~ DSP_VTOTAL-1) |
| 15:12      | RO          | 0x0                | reserved                                                                                                      |
| 11:0       | RW          | 0x000              | dsp_line_flag0_num<br>The display line number when the flag interrupt occur, the range is (0~ DSP_VTOTAL-1)   |

**VOP BIG INTR EN**

Address: Operational Base + offset (0x0034)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_mask<br>When every bit HIGH, enable the writing corresponding bit<br>When every bit LOW, don't care the writing corresponding bit |
| 15         | RW          | 0x0                | mmu_irq_intr_en<br>1'b0: DISABLE<br>1'b1: ENABLE                                                                                        |
| 14         | RO          | 0x0                | reserved                                                                                                                                |
| 13         | RW          | 0x0                | post_lb_almost_empty_intr_en<br>1'b0: DISABLE<br>1'b1: ENABLE                                                                           |
| 12         | RW          | 0x0                | post_lb_almost_full_intr_en<br>1'b0: DISABLE<br>1'b1: ENABLE                                                                            |
| 11         | RW          | 0x0                | post_empty_intr_en<br>1'b0: DISABLE<br>1'b1: ENABLE                                                                                     |
| 10         | RO          | 0x0                | reserved                                                                                                                                |
| 9          | RW          | 0x0                | dma_frm_fsh_intr_en<br>1'b0: DISABLE<br>1'b1: ENABLE                                                                                    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                      |
|------------|-------------|--------------------|---------------------------------------------------------|
| 8          | RW          | 0x0                | dsp_hold_valid_intr_en<br>1'b0: DISABLE<br>1'b1: ENABLE |
| 7          | RW          | 0x0                | win1_empty_intr_en<br>1'b0: DISABLE<br>1'b1: ENABLE     |
| 6          | RW          | 0x0                | win0_empty_intr_en<br>1'b0: DISABLE<br>1'b1: ENABLE     |
| 5          | RW          | 0x0                | bus_error_intr_en<br>1'b0: DISABLE<br>1'b1: ENABLE      |
| 4          | RW          | 0x0                | line_flag1_intr_en<br>1'b0: DISABLE<br>1'b1: ENABLE     |
| 3          | RW          | 0x0                | line_flag0_intr_en<br>1'b0: DISABLE<br>1'b1: ENABLE     |
| 2          | RW          | 0x0                | addr_same_intr_en<br>1'b0: DISABLE<br>1'b1: ENABLE      |
| 1          | RW          | 0x0                | fs1_intr_en<br>1'b0: DISABLE<br>1'b1: ENABLE            |
| 0          | RW          | 0x0                | fs0_intr_en<br>1'b0: DISABLE<br>1'b1: ENABLE            |

**VOP BIG INTR CLEAR**

Address: Operational Base + offset (0x0038)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                             |
|------------|-------------|--------------------|----------------------------------------------------------------|
| 31:16      | RO          | 0x0                | reserved                                                       |
| 15         | RW          | 0x0                | mmu_irq_intr_clr<br>1'b0: DISABLE<br>1'b1: ENABLE              |
| 14         | RO          | 0x0                | reserved                                                       |
| 13         | RW          | 0x0                | post_lb_almost_empty_intr_clr<br>1'b0: DISABLE<br>1'b1: ENABLE |
| 12         | RW          | 0x0                | post_lb_almost_full_intr_clr<br>1'b0: DISABLE<br>1'b1: ENABLE  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 11         | RW          | 0x0                | post_empty_intr_clr<br>1'b0: DISABLE<br>1'b1: ENABLE     |
| 10         | RO          | 0x0                | reserved                                                 |
| 9          | RW          | 0x0                | dma_frm_fsh_intr_clr<br>1'b0: DISABLE<br>1'b1: ENABLE    |
| 8          | W1C         | 0x0                | dsp_hold_valid_intr_clr<br>1'b0: DISABLE<br>1'b1: ENABLE |
| 7          | W1C         | 0x0                | win1_empty_intr_clr<br>1'b0: DISABLE<br>1'b1: ENABLE     |
| 6          | W1C         | 0x0                | win0_empty_intr_clr<br>1'b0: DISABLE<br>1'b1: ENABLE     |
| 5          | W1C         | 0x0                | bus_error_intr_clr<br>1'b0: DISABLE<br>1'b1: ENABLE      |
| 4          | W1C         | 0x0                | line_flag1_intr_clr<br>1'b0: DISABLE<br>1'b1: ENABLE     |
| 3          | W1C         | 0x0                | line_flag0_intr_clr<br>1'b0: DISABLE<br>1'b1: ENABLE     |
| 2          | W1C         | 0x0                | addr_same_intr_clr<br>1'b0: DISABLE<br>1'b1: ENABLE      |
| 1          | W1C         | 0x0                | fs1_intr_clr<br>1'b0: DISABLE<br>1'b1: ENABLE            |
| 0          | W1C         | 0x0                | fs0_intr_clr<br>1'b0: DISABLE<br>1'b1: ENABLE            |

**VOP BIG INTR STATUS**

Address: Operational Base + offset (0x003c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                             |
|------------|-------------|--------------------|--------------------------------------------------------------------------------|
| 31         | RW          | 0x0                | mmu_intr_raw_status<br>mmu interrupt raw status                                |
| 30         | RO          | 0x0                | reserved                                                                       |
| 29         | RW          | 0x0                | post_lb_almost_empty_intr_raw_sts<br>post lb almost empty interrupt raw status |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------|
| 28         | RW          | 0x0                | post_lb_almost_full_intr_raw<br>post lb almost full interrupt raw status |
| 27         | RW          | 0x0                | post_empty_intr_raw<br>post lb empty interrupt raw status                |
| 26         | RO          | 0x0                | reserved                                                                 |
| 25         | RO          | 0x0                | dma_frm_fsh_intr_raw_sts<br>dma finish interrupt raw status              |
| 24         | RO          | 0x0                | dsp_hold_valid_intr_raw_sts<br>display hold interrupt raw status         |
| 23         | RO          | 0x0                | win1_empty_intr_raw_sts<br>win1 empty interrupt raw status               |
| 22         | RO          | 0x0                | win0_empty_intr_raw_sts<br>win0 empty interrupt raw status               |
| 21         | RO          | 0x0                | bus_error_intr_raw_sts<br>bus error interrupt raw status                 |
| 20         | RO          | 0x0                | line_flag1_intr_raw_sts<br>line flag1 interrupt raw status               |
| 19         | RO          | 0x0                | line_flag0_intr_raw_sts<br>line flag0 interrupt raw status               |
| 18         | RW          | 0x0                | addr_same_intr_raw_sts<br>same address interrupt raw status              |
| 17         | RO          | 0x0                | fs1_intr_raw_sts<br>new frame start interrupt raw status                 |
| 16         | RO          | 0x0                | fs0_intr_raw_sts<br>frame start interrupt raw status                     |
| 15         | RO          | 0x0                | mmu_intr_status<br>mmu interrupt status                                  |
| 14         | RO          | 0x0                | reserved                                                                 |
| 13         | RW          | 0x0                | post_lb_almost_empty_intr_sts<br>post lb almost empty interrupt status   |
| 12         | RW          | 0x0                | post_lb_almost_full_intr<br>post lb almost full interrupt status         |
| 11         | RW          | 0x0                | post_empty_intr_sts<br>post lb empty interrupt status                    |
| 10         | RO          | 0x0                | reserved                                                                 |
| 9          | RW          | 0x0                | dma_frm_fsh_intr_sts<br>dma finish interrupt status                      |
| 8          | RO          | 0x0                | dsp_hold_valid_intr_sts<br>display hold interrupt status                 |
| 7          | RO          | 0x0                | win1_empty_intr_sts<br>win1 empty interrupt status                       |
| 6          | RO          | 0x0                | win0_empty_intr_sts<br>win0 empty interrupt status                       |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                  |
|------------|-------------|--------------------|-----------------------------------------------------|
| 5          | RO          | 0x0                | bus_error_intr_sts<br>bus error interrupt status    |
| 4          | RO          | 0x0                | line_flag1_intr_sts<br>line flag1 interrupt status  |
| 3          | RO          | 0x0                | line_flag0_intr_sts<br>line flag0 interrupt status  |
| 2          | RW          | 0x0                | addr_same_intr_sts<br>same address interrupt status |
| 1          | RW          | 0x0                | fs1_intr_sts<br>new frame start interrupt status    |
| 0          | RO          | 0x0                | fs0_intr_sts<br>frame start interrupt status        |

**VOP\_BIG\_WIN0\_CTRL0**

Address: Operational Base + offset (0x0050)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20      | RO          | 0x0                | reserved                                                                                                                                                             |
| 19         | RW          | 0x0                | win0_cbr_deflick<br>1'b0: disable<br>1'b1: enable                                                                                                                    |
| 18         | RW          | 0x0                | win0_yrgb_deflick<br>1'b0: disable<br>1'b1: enable                                                                                                                   |
| 17:16      | RO          | 0x0                | reserved                                                                                                                                                             |
| 15         | RW          | 0x0                | win0_uv_swap<br>1'b0: CrCb<br>1'b1: CbCr                                                                                                                             |
| 14         | RW          | 0x0                | win0_mid_swap<br>1'b0: Y3Y2Y1Y0<br>1'b1: Y3Y1Y2Y0                                                                                                                    |
| 13         | RW          | 0x0                | win0_alpha_swap<br>1'b0: ARGB<br>1'b1: RGBA                                                                                                                          |
| 12         | RW          | 0x0                | win0_rb_swap<br>1'b0: RGB<br>1'b1: BGR                                                                                                                               |
| 11:10      | RW          | 0x0                | win0_csc_mode<br>Color space conversion:<br>2'b00/11: mpeg<br>2'b01: hd<br>2'b10: jpeg<br>reused by win0 r2y color space conversion:<br>2'bX0: BT601<br>2'bX1: BT709 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9          | RW          | 0x0                | win0_no_outstanding<br>1'b0: enable<br>1'b1: disable                                                                                                       |
| 8          | RW          | 0x0                | win0_interlace_read<br>1'b0: disable<br>1'b1: enable                                                                                                       |
| 7:4        | RO          | 0x0                | reserved                                                                                                                                                   |
| 3:1        | RW          | 0x0                | win0_data_fmt<br>3'b000 : ARGB888<br>3'b001 : RGB888<br>3'b010 : RGB565<br>3'b100 : YCbCr420<br>3'b101 : YCbCr422<br>3'b110 : YCbCr444<br>others: reserved |
| 0          | RW          | 0x0                | win0_en<br>1'b0: Win0 layer disable<br>1'b1: Win0 layer enable                                                                                             |

**VOP BIG WIN0 CTRL1**

Address: Operational Base + offset (0x0054)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20      | RO          | 0x0                | reserved                                                                                                                                                              |
| 19:16      | RW          | 0x2                | sw_win0_cbr0_rid                                                                                                                                                      |
| 15:12      | RW          | 0x1                | sw_win0_yrgb0_rid                                                                                                                                                     |
| 11:8       | RW          | 0x2                | win0_cbr_axi_gather_num                                                                                                                                               |
| 7:4        | RW          | 0x2                | win0_yrgb_axi_gather_num                                                                                                                                              |
| 3:2        | RW          | 0x0                | win0_dma_burst_length<br>2'b00: burst16 (burst 15 in rgb888 pack mode)<br>2'b01: burst8 (burst 12 in rgb888 pack mode)<br>2'b10: burst4 (burst 6 in rgb888 pack mode) |
| 1          | RW          | 0x0                | win0_cbr_axi_gather_en<br>1'b0: disable<br>1'b1: enable                                                                                                               |
| 0          | WO          | 0x0                | win0_yrgb_axi_gather_en<br>1'b0: disable<br>1'b1: enable                                                                                                              |

**VOP BIG WIN0 COLOR KEY**

Address: Operational Base + offset (0x0058)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                           |
|------------|-------------|--------------------|----------------------------------------------|
| 31:25      | RO          | 0x0                | reserved                                     |
| 24         | RW          | 0x0                | win0_key_en<br>1'b0: disable<br>1'b1: enable |
| 23:0       | RW          | 0x0000000          | win0_key_color<br>win0 color key             |

**VOP BIG WIN0 VIR**

Address: Operational Base + offset (0x005c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:29      | RO          | 0x0                | reserved                                                                                                                                                                                                                                          |
| 28:16      | RW          | 0x0140             | win0_cbr_vir_stride<br>UV420 : ceil(win0_cbr_vir_stride/4)<br>UV422 : ceil(win0_cbr_vir_stride/4)<br>UV444 : ceil(win0_cbr_vir_stride/2)                                                                                                          |
| 15:13      | RO          | 0x0                | reserved                                                                                                                                                                                                                                          |
| 12:0       | RW          | 0x0140             | win0_yrgb_vir_stride<br>Number of words of Win0 Virtual width<br>ARGB888 : win0_yrgb_vir_stride<br>RGB888 : (win0_yrgb_vir_stride*3/4) +<br>win0_yrgb_vir_stride%3<br>RGB565 : ceil(win0_yrgb_vir_stride/2)<br>YUV : ceil(win0_yrgb_vir_stride/4) |

**VOP BIG WIN0 YRGB MST0**

Address: Operational Base + offset (0x0060)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                               |
|------------|-------------|--------------------|--------------------------------------------------|
| 31:0       | RW          | 0x000000000        | win0_yrgb0_mst<br>win0 yrgb memory start address |

**VOP BIG WIN0 CBR MST0**

Address: Operational Base + offset (0x0064)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                              |
|------------|-------------|--------------------|-------------------------------------------------|
| 31:0       | RW          | 0x000000000        | win0_cbr0_mst<br>win0 cbcr memory start address |

**VOP BIG WIN0 ACT INFO**

Address: Operational Base + offset (0x0068)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                          |
|------------|-------------|--------------------|-------------------------------------------------------------|
| 31:29      | RO          | 0x0                | reserved                                                    |
| 28:16      | RW          | 0x00ef             | win0_act_height<br>win_act_height = (win0 vertical size -1) |
| 15:13      | RO          | 0x0                | reserved                                                    |
| 12:0       | RW          | 0x013f             | win0_act_width<br>win_act_width = (win0 horizontal size -1) |

**VOP\_BIG\_WINO\_DSP\_INFO**

Address: Operational Base + offset (0x006c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                           |
|------------|-------------|--------------------|--------------------------------------------------------------|
| 31:27      | RO          | 0x0                | reserved                                                     |
| 26:16      | RW          | 0x0ef              | dsp_wino_height<br>win0_dsp_height = (win0 vertical size -1) |
| 15:11      | RO          | 0x0                | reserved                                                     |
| 10:0       | RW          | 0x13f              | dsp_wino_width<br>win0_dsp_width = (win0 horizontal size -1) |

**VOP\_BIG\_WINO\_DSP\_ST**

Address: Operational Base + offset (0x0070)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                      |
|------------|-------------|--------------------|-----------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                |
| 27:16      | RW          | 0x000              | dsp_wino_yst<br>win0 y-axis start point |
| 15:12      | RO          | 0x0                | reserved                                |
| 11:0       | RW          | 0x00a              | dsp_wino_xst<br>win0 x-axis start point |

**VOP\_BIG\_WINO\_SCL\_FACTOR\_YRGB**

Address: Operational Base + offset (0x0074)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x1000             | win0_vs_factor_yrgb<br>factor=((VOP_WINO_ACT_INFO[31:16])/(VOP_WINO_DSP_INFO[31:16]))*2^12 |
| 15:0       | RW          | 0x1000             | win0_hs_factor_yrgb<br>factor=((VOP_WINO_ACT_INFO[15:0])/(VOP_WINO_DSP_INFO[15:0]))*2^12   |

**VOP\_BIG\_WINO\_SCL\_FACTOR\_CBR**

Address: Operational Base + offset (0x0078)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x1000             | win0_vs_factor_cbr<br>YCbCr420:<br>factor=((VOP_WIN0_ACT_INFO[31:16]/<br>2)/(VOP_WIN0_DSP_INFO[31:16] ))*2^12<br>YCbCr422,YCbCr444:<br>factor=((VOP_WIN0_ACT_INFO[31:16])/(VOP_WIN0_DSP_INFO[<br>31:16] ))*2^12 |
| 15:0       | RW          | 0x1000             | win0_hs_factor_cbr<br>YCbCr422,YCbCr420:<br>factor=((VOP_WIN0_ACT_INFO[15:0]/2)/(VOP_WIN0_DSP_INFO<br>[15:0] ))*2^12<br>YCbCr444:<br>factor=((VOP_WIN0_ACT_INFO[15:0])/(VOP_WIN0_DSP_INFO[1<br>5:0] ))*2^12     |

**VOP\_BIG\_WIN0\_SCL\_OFFSET**

Address: Operational Base + offset (0x007c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                |
|------------|-------------|--------------------|---------------------------------------------------|
| 31:24      | RW          | 0x00               | win0_vs_offset_cbr<br>(0x00~0xff)/0x100 = 0~0.99  |
| 23:16      | RW          | 0x00               | win0_vs_offset_yrgb<br>(0x00~0xff)/0x100 = 0~0.99 |
| 15:8       | RW          | 0x00               | win0_hs_offset_cbr<br>(0x00~0xff)/0x100 = 0~0.99  |
| 7:0        | RW          | 0x00               | win0_hs_offset_yrgb<br>(0x00~0xff)/0x100 = 0~0.99 |

**VOP\_BIG\_WIN0\_ALPHA\_CTRL**

Address: Operational Base + offset (0x0080)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------|
| 31:12      | RO          | 0x0                | reserved                                                                               |
| 11:4       | RW          | 0x00               | win0_alpha_value<br>win0 global alpha value                                            |
| 3          | RW          | 0x0                | win0_alpha_sat_mode<br>1'b0 : alpha value no change<br>1'b1 : alpha = alpha + alpha[7] |
| 2          | RW          | 0x0                | win0_alpha_pre_mul<br>1'b0 : Non-premultiplied alpha<br>1'b1 : Premultiplied alpha     |
| 1          | RW          | 0x0                | win0_alpha_mode<br>1'b0: user-defined alpha<br>1'b1: per-pixel alpha                   |
| 0          | RW          | 0x0                | win0_alpha_en<br>1'b0: disable<br>1'b1: enable                                         |

**VOP BIG WIN1 CTRL0**

Address: Operational Base + offset (0x0090)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------|
| 31:14      | RO          | 0x0                | reserved                                                                                    |
| 13         | RW          | 0x0                | win1_alpha_swap<br>1'b0: ARGB<br>1'b1: RGBA                                                 |
| 12         | RW          | 0x0                | win1_rb_swap<br>1'b0: RGB<br>1'b1: BGR                                                      |
| 11:10      | RO          | 0x0                | reserved                                                                                    |
| 9          | RW          | 0x0                | win1_no_outstanding<br>1'b0: enable<br>1'b1: disable                                        |
| 8          | RW          | 0x0                | win1_interlace_read<br>1'b0: disable<br>1'b1: enable                                        |
| 7          | RO          | 0x0                | reserved                                                                                    |
| 6:4        | RW          | 0x0                | win1_data_fmt<br>3'b000 : ARGB888<br>3'b001 : RGB888<br>3'b010 : RGB565<br>others: reserved |
| 3:1        | RO          | 0x0                | reserved                                                                                    |
| 0          | RW          | 0x0                | win1_en<br>1'b0: Win1 layer disable<br>1'b1: Win1 layer enable                              |

**VOP BIG WIN1 CTRL1**

Address: Operational Base + offset (0x0094)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:12      | RO          | 0x0                | reserved                                                                                                                                                              |
| 11:8       | RW          | 0x5                | sw_win1_rid<br>win1 axi read id                                                                                                                                       |
| 7:4        | RW          | 0x0                | win1_axi_gather_num<br>win1 axi gather_num gather number                                                                                                              |
| 3:2        | RW          | 0x0                | win1_dma_burst_length<br>2'b00: burst16 (burst 15 in rgb888 pack mode)<br>2'b01: burst8 (burst 12 in rgb888 pack mode)<br>2'b10: burst4 (burst 6 in rgb888 pack mode) |
| 1          | RO          | 0x0                | reserved                                                                                                                                                              |
| 0          | RW          | 0x0                | win1_axi_gather_en<br>1'b0: disable<br>1'b1: enable                                                                                                                   |

**VOP BIG WIN1 VIR**

Address: Operational Base + offset (0x0098)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:13      | RO          | 0x0                | reserved                                                                                                                                                                      |
| 12:0       | RW          | 0x0000             | win1_vir_stride<br>Number of words of Win1 Virtual width<br>ARGB888 : win1_vir_width<br>RGB888 : (win1_vir_width*3/4) + (win1_vir_width%3)<br>RGB565 : ceil(win1_vir_width/2) |

**VOP BIG WIN1 MST**

Address: Operational Base + offset (0x00a0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b> |
|------------|-------------|--------------------|--------------------|
| 31:0       | RW          | 0x00000000         | win1_mst           |

**VOP BIG WIN1 DSP INFO**

Address: Operational Base + offset (0x00a4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                               |
|------------|-------------|--------------------|------------------------------------------------------------------|
| 31:27      | RO          | 0x0                | reserved                                                         |
| 26:16      | RW          | 0x0ef              | dsp_win1_height<br>win1_dsp_height = (win1 dsp vertical size -1) |
| 15:11      | RO          | 0x0                | reserved                                                         |
| 10:0       | RW          | 0x13f              | dsp_win1_width<br>win1_dsp_width = (win1 dsp horizontal size -1) |

**VOP BIG WIN1 DSP ST**

Address: Operational Base + offset (0x00a8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                      |
|------------|-------------|--------------------|-----------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                |
| 27:16      | RW          | 0x000              | dsp_win1_yst<br>win1 y-axis start point |
| 15:12      | RO          | 0x0                | reserved                                |
| 11:0       | RW          | 0x00a              | dsp_win1_xst<br>win1 x-axis start point |

**VOP BIG WIN1 COLOR KEY**

Address: Operational Base + offset (0x00ac)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                           |
|------------|-------------|--------------------|----------------------------------------------|
| 31:25      | RO          | 0x0                | reserved                                     |
| 24         | RW          | 0x0                | win1_key_en<br>1'b0: disable<br>1'b1: enable |
| 23:0       | RW          | 0x000000           | win1_key_color<br>win1 color key             |

**VOP BIG WIN1 ALPHA CTRL**

Address: Operational Base + offset (0x00bc)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------|
| 31:12      | RO          | 0x0                | reserved                                                                               |
| 11:4       | RW          | 0x00               | win1_alpha_value<br>win1 global alpha value                                            |
| 3          | RW          | 0x0                | win1_alpha_sat_mode<br>1'b0 : alpha value no change<br>1'b1 : alpha = alpha + alpha[7] |
| 2          | RW          | 0x0                | win1_alpha_pre_mul<br>1'b0 : Non-premultiplied alpha<br>1'b1 : Premultiplied alpha     |
| 1          | RW          | 0x0                | win1_alpha_mode<br>1'b0: user-defined alpha<br>1'b1: per-pixel alpha                   |
| 0          | RW          | 0x0                | win1_alpha_en<br>1'b0: disable<br>1'b1: enable                                         |

**VOP BIG HWC CTRL0**

Address: Operational Base + offset (0x00e0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>            |
|------------|-------------|--------------------|-------------------------------|
| 31:8       | RO          | 0x0                | reserved                      |
| 7:4        | RW          | 0x0                | sw_hwc_rid<br>hwc axi read id |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| 3          | RW          | 0x0                | hwc_lut_en<br>1'b0: disable<br>1'b1: enable<br>*This bit should be "0" when CPU updates the LUT, and should be "1" when hwc LUT mode enable |
| 2          | RW          | 0x0                | hwc_load_en<br>1'b0: disable<br>1'b1: enable<br>*Setting this bit would reload the Hwc data. It would be auto cleared after reload finish   |
| 1          | RW          | 0x0                | hwc_size<br>1'b0: 32x32<br>1'b1: 64x64                                                                                                      |
| 0          | RW          | 0x0                | hwc_en<br>1'b0: Hwc layer disable<br>1'b1: Hwc layer enable                                                                                 |

**VOP BIG HWC MST**

Address: Operational Base + offset (0x00e8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                  |
|------------|-------------|--------------------|-------------------------------------|
| 31:0       | RW          | 0x00000000         | hwc_mst<br>hwc memory start address |

**VOP BIG HWC DSP ST**

Address: Operational Base + offset (0x00ec)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                    |
|------------|-------------|--------------------|---------------------------------------|
| 31:28      | RO          | 0x0                | reserved                              |
| 27:16      | RW          | 0x000              | dsp_hwc_yst<br>hwc y-axis start point |
| 15:12      | RO          | 0x0                | reserved                              |
| 11:0       | RW          | 0x000              | dsp_hwc_xst<br>hwc x-axis start point |

**VOP BIG HWC ALPHA CTRL**

Address: Operational Base + offset (0x00f0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------|
| 31:12      | RO          | 0x0                | reserved                                                                              |
| 11:4       | RW          | 0x00               | hwc_alpha_value<br>hwc global alpha value                                             |
| 3          | RW          | 0x0                | hwc_alpha_sat_mode<br>1'b0 : alpha value no change<br>1'b1 : alpha = alpha + alpha[7] |
| 2          | RW          | 0x0                | hwc_alpha_pre_mul<br>1'b0 : Non-premultiplied alpha<br>1'b1 : Premultiplied alpha     |
| 1          | RW          | 0x0                | hwc_alpha_mode<br>1'b0: user-defined alpha<br>1'b1: per-pixel alpha                   |
| 0          | RW          | 0x0                | hwc_alpha_en<br>1'b0: disable<br>1'b1: enable                                         |

**VOP BIG DSP HTOTAL HS END**

Address: Operational Base + offset (0x0100)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>       |
|------------|-------------|--------------------|--------------------------|
| 31:28      | RO          | 0x0                | reserved                 |
| 27:16      | RW          | 0x14a              | dsp_htotal<br>dsp_htotal |
| 15:12      | RO          | 0x0                | reserved                 |
| 11:0       | RW          | 0x00a              | dsp_hs_end<br>dsp_hs_end |

**VOP BIG DSP HACT ST END**

Address: Operational Base + offset (0x0104)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>           |
|------------|-------------|--------------------|------------------------------|
| 31:28      | RO          | 0x0                | reserved                     |
| 27:16      | RW          | 0x00a              | dsp_hact_st<br>dsp_hact_st   |
| 15:12      | RO          | 0x0                | reserved                     |
| 11:0       | RW          | 0x000              | dsp_hact_end<br>dsp_hact_end |

**VOP BIG DSP VTOTAL VS END**

Address: Operational Base + offset (0x0108)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>       |
|------------|-------------|--------------------|--------------------------|
| 31:28      | RO          | 0x0                | reserved                 |
| 27:16      | RW          | 0x0fa              | dsp_vtotal<br>dsp_vtotal |
| 15:12      | RO          | 0x0                | reserved                 |
| 11:0       | RW          | 0x00a              | dsp_vs_end<br>dsp_vs_end |

**VOP\_BIG\_DSP\_VACT\_ST\_END**

Address: Operational Base + offset (0x010c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>           |
|------------|-------------|--------------------|------------------------------|
| 31:28      | RO          | 0x0                | reserved                     |
| 27:16      | RW          | 0x00a              | dsp_vact_st<br>dsp_vact_st   |
| 15:12      | RO          | 0x0                | reserved                     |
| 11:0       | RW          | 0x0fa              | dsp_vact_end<br>dsp_vact_end |

**VOP\_BIG\_DSP\_VS\_ST\_END\_F1**

Address: Operational Base + offset (0x0110)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                                                                   |
| 27:16      | RW          | 0x000              | dsp_vs_st_f1<br>Panel display scanning vertical vsync start point of 2nd field<br>(interlace display mode) |
| 15:12      | RO          | 0x0                | reserved                                                                                                   |
| 11:0       | RW          | 0x000              | dsp_vs_end_f1<br>Panel display scanning vertical vsync end point of 2nd<br>field(interlace display mode)   |

**VOP\_BIG\_DSP\_VACT\_ST\_END\_F1**

Address: Operational Base + offset (0x0114)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                                                                      |
| 27:16      | RW          | 0x000              | dsp_vact_st_f1<br>Panel display scanning vertical active start point of 2nd field<br>(interlace display mode) |
| 15:12      | RO          | 0x0                | reserved                                                                                                      |
| 11:0       | RW          | 0x000              | dsp_vact_end_f1<br>Panel display scanning vertical active end point of 2nd field<br>(interlace display mode)  |

**VOP\_BIG\_BCSH\_CTRL**

Address: Operational Base + offset (0x0160)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                             |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                                                                       |
| 7          | RW          | 0x0                | sw_bcsrh_r2y_en<br>1'b0:bypass<br>1'b1:enable                                                  |
| 6          | RW          | 0x0                | sw_bcsrh_y2r_en<br>1'b0:bypass<br>1'b1:enable                                                  |
| 5:4        | RW          | 0x0                | sw_bcsrh_y2r_csc_mode<br>Color space conversion:<br>2'b00/11: mpeg<br>2'b01: hd<br>2'b10: jpeg |
| 3:2        | RW          | 0x0                | video_mode<br>2'b00 : black<br>2'b01 : blue<br>2'b10 : color bar<br>2'b11 : normal video       |
| 1          | RW          | 0x0                | sw_bcsrh_r2y_csc_mode<br>Color space conversion:<br>1'b0: BT601<br>1'b1: BT709                 |
| 0          | RW          | 0x0                | bcsrh_en<br>1'b0 : bcsrh bypass<br>1'b1 : bcsrh enable                                         |

**VOP\_BIG\_BCSH\_COL\_BAR**

Address: Operational Base + offset (0x0164)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                      |
|------------|-------------|--------------------|-----------------------------------------|
| 31:24      | RO          | 0x0                | reserved                                |
| 23:16      | RW          | 0x00               | color_bar_v<br>v component of color bar |
| 15:8       | RW          | 0x00               | color_bar_u<br>u component of color bar |
| 7:0        | RW          | 0x00               | color_bar_y<br>y component of color bar |

**VOP\_BIG\_BCSH\_BCS**

Address: Operational Base + offset (0x0168)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                 |
|------------|-------------|--------------------|----------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                           |
| 29:20      | RW          | 0x000              | sat_con<br>Saturation*Contrast*256 : 0,1.992*1.992 |
| 19:17      | RO          | 0x0                | reserved                                           |
| 16:8       | RW          | 0x000              | contrast<br>Contrast*256 : 0,1.992                 |
| 7          | RO          | 0x0                | reserved                                           |
| 6:0        | RW          | 0x00               | brightness<br>Brightness : -128,127                |

**VOP\_BIG\_BCSH\_H**

Address: Operational Base + offset (0x016c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b> |
|------------|-------------|--------------------|--------------------|
| 31:25      | RO          | 0x0                | reserved           |
| 24:16      | RW          | 0x000              | cos_hue<br>cos_hue |
| 15:9       | RO          | 0x0                | reserved           |
| 8:0        | RW          | 0x000              | sin_hue<br>sin_hue |

**VOP\_BIG\_FRC\_LOWER01\_0**

Address: Operational Base + offset (0x0170)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>           |
|------------|-------------|--------------------|------------------------------|
| 31:16      | RW          | 0x1284             | lower01_frm1<br>lower01_frm1 |
| 15:0       | RW          | 0x4821             | lower01_frm0<br>lower01_frm0 |

**VOP\_BIG\_FRC\_LOWER01\_1**

Address: Operational Base + offset (0x0174)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>           |
|------------|-------------|--------------------|------------------------------|
| 31:16      | RW          | 0x2148             | lower01_frm3<br>lower01_frm3 |
| 15:0       | RW          | 0x8412             | lower01_frm2<br>lower01_frm2 |

**VOP\_BIG\_FRC\_LOWER10\_0**

Address: Operational Base + offset (0x0178)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>           |
|------------|-------------|--------------------|------------------------------|
| 31:16      | RW          | 0xa55a             | lower10_frm1<br>lower10_frm1 |
| 15:0       | RW          | 0x9696             | lower10_frm0<br>lower10_frm0 |

**VOP BIG FRC LOWER10 1**

Address: Operational Base + offset (0x017c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>           |
|------------|-------------|--------------------|------------------------------|
| 31:16      | RW          | 0x5aa5             | lower10_frm3<br>lower10_frm3 |
| 15:0       | RW          | 0x6969             | lower10_frm2<br>lower10_frm2 |

**VOP BIG FRC LOWER11 0**

Address: Operational Base + offset (0x0180)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>           |
|------------|-------------|--------------------|------------------------------|
| 31:16      | RW          | 0xdeb7             | lower11_frm1<br>lower11_frm1 |
| 15:0       | RW          | 0x7bed             | lower11_frm0<br>lower11_frm0 |

**VOP BIG FRC LOWER11 1**

Address: Operational Base + offset (0x0184)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>           |
|------------|-------------|--------------------|------------------------------|
| 31:16      | RW          | 0xed7b             | lower11_frm3<br>lower11_frm3 |
| 15:0       | RW          | 0xb7de             | lower11_frm2<br>lower11_frm2 |

**VOP BIG MCU RW BYPASS PORT**

Address: Operational Base + offset (0x018c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                             |
|------------|-------------|--------------------|------------------------------------------------|
| 31:0       | RW          | 0x00000000         | mcu_write_data_bypass<br>mcu write bypass data |

**VOP BIG DBG REG SCAN LINE**

Address: Operational Base + offset (0x0190)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b> |
|------------|-------------|--------------------|--------------------|
| 31:12      | RO          | 0x0                | reserved           |
| 11:0       | RO          | 0x000              | scan_line_num      |

**VOP BIG WIN2 CTRL0**

Address: Operational Base + offset (0x0190)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------|
| 31         | RW          | 0x0                | win2_endian_swap3<br>1'b0 : Big-endian<br>1'b1 : Little-endian                        |
| 30         | RW          | 0x0                | win2_alpha_swap3<br>1'b0 : ARGB<br>1'b1 : RGBA                                        |
| 29         | RW          | 0x0                | win2_rb_swap3<br>1'b0 : RGB<br>1'b1 : BGR                                             |
| 28         | RW          | 0x0                | win2_endian_swap2<br>1'b0 : Big-endian<br>1'b1 : Little-endian                        |
| 27         | RW          | 0x0                | win2_alpha_swap2<br>1'b0 : ARGB<br>1'b1 : RGBA                                        |
| 26         | RW          | 0x0                | win2_rb_swap2<br>1'b0 : RGB<br>1'b1 : BGR                                             |
| 25         | RW          | 0x0                | win2_endian_swap1<br>1'b0 : Big-endian<br>1'b1 : Little-endian                        |
| 24         | RW          | 0x0                | win2_alpha_swap1<br>1'b0 : ARGB<br>1'b1 : RGBA                                        |
| 23         | RW          | 0x0                | win2_rb_swap1<br>1'b0 : RGB<br>1'b1 : BGR                                             |
| 22         | RW          | 0x0                | win2_endian_swap0<br>1'b0 : Big-endian<br>1'b1 : Little-endian                        |
| 21         | RW          | 0x0                | win2_alpha_swap0<br>1'b0 : ARGB<br>1'b1 : RGBA                                        |
| 20         | RW          | 0x0                | win2_rb_swap0<br>1'b0 : RGB<br>1'b1 : BGR                                             |
| 19         | RO          | 0x0                | reserved                                                                              |
| 18:17      | RW          | 0x0                | win2_data_fmt3<br>2'b00 : ARGB888<br>2'b01 : RGB888<br>2'b10 : RGB565<br>2'b11 : 8bpp |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------|
| 16         | RW          | 0x0                | win2_mst3_en<br>1'b0 : disable<br>1'b1 : enable                                                                 |
| 15         | RO          | 0x0                | reserved                                                                                                        |
| 14:13      | RW          | 0x0                | win2_data_fmt2<br>2'b00 : ARGB888<br>2'b01 : RGB888<br>2'b10 : RGB565<br>2'b11 : 8bpp                           |
| 12         | RW          | 0x0                | win2_mst2_en<br>1'b0 : disable<br>1'b1 : enable                                                                 |
| 11         | RO          | 0x0                | reserved                                                                                                        |
| 10:9       | RW          | 0x0                | win2_data_fmt1<br>2'b00 : ARGB888<br>2'b01 : RGB888<br>2'b10 : RGB565<br>2'b11 : 8bpp                           |
| 8          | RW          | 0x0                | win2_mst1_en<br>1'b0 : disable<br>1'b1 : enable                                                                 |
| 7          | RO          | 0x0                | reserved                                                                                                        |
| 6:5        | RW          | 0x0                | win2_data_fmt0<br>2'b00 : ARGB888<br>2'b01 : RGB888<br>2'b10 : RGB565<br>2'b11 : 8bpp                           |
| 4          | RW          | 0x0                | win2_mst0_en<br>1'b0 : disable<br>1'b1 : enable                                                                 |
| 3:2        | RW          | 0x0                | win2_csc_mode<br>Color space conversion:<br>2'b00: BT601_L<br>2'b01: BT709_L<br>2'b10: BT601_F<br>2'b11: BT2020 |
| 1          | RW          | 0x0                | win2_interlace_read<br>1'b0 : disable<br>1'b1 : enable                                                          |
| 0          | RW          | 0x0                | win2_en<br>1'b0 : disable<br>1'b1 : enable                                                                      |

**VOP\_BIG\_WIN2\_CTRL1**

Address: Operational Base + offset (0x0194)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:22      | RO          | 0x0                | reserved                                                                                                                                                                                     |
| 21:17      | RW          | 0x1d               | win2_axi_max_outstanding_num<br>win2 axi max outstanding number                                                                                                                              |
| 16         | RW          | 0x0                | win2_axi_max_outstanding_en<br>1'b0 : disable<br>1'b1 : enable                                                                                                                               |
| 15         | RW          | 0x0                | win2_y_mir_en<br>1'b0 : no y_mirror<br>1'b1 : y_mirror                                                                                                                                       |
| 14         | RW          | 0x0                | win2_no_outstanding<br>1'b0 : enable<br>1'b1 : disable                                                                                                                                       |
| 13:12      | RO          | 0x0                | reserved                                                                                                                                                                                     |
| 11:8       | RW          | 0x0                | win2_rid<br>axi read id of win2 channel                                                                                                                                                      |
| 7:4        | RW          | 0x0                | win2_axi_gather_num<br>win2 axi gather transfer number                                                                                                                                       |
| 3:2        | RW          | 0x0                | win2_dma_burst_length<br>2'b00 : burst16 (burst 15 in rgb888 pack mode)<br>2'b01 : burst8 (burst 12 in rgb888 pack mode)<br>2'b10 : burst4 (burst 6 in rgb888 pack mode)<br>2'b11 : reserved |
| 1          | RO          | 0x0                | reserved                                                                                                                                                                                     |
| 0          | RW          | 0x0                | win2_axi_gather_en<br>1'b0 : disable<br>1'b1 : enable                                                                                                                                        |

**VOP BIG WIN2 VIRO 1**

Address: Operational Base + offset (0x0198)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0140             | win2_vir_stride1<br>Number of words of Win2 Virtual1 width<br>ARGB888 : win2_vir_width1<br>RGB888 : (win2_vir_width1 * 3/4) + (win2_vir_width1 % 3)<br>RGB565 : ceil(win2_vir_width1 / 2)<br>8BPP : ceil(win2_vir_width1 / 4)<br>4BPP : ceil(win2_vir_width1 / 8)<br>2BPP : ceil(win2_vir_width1 / 16)<br>1BPP : ceil(win2_vir_width1 / 32) |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0       | RW          | 0x0140             | win2_vir_stride0<br>Number of words of Win2 Virtual0 width<br>ARGB888 : win2_vir_width0<br>RGB888 : (win2_vir_width0 * 3/4) + (win2_vir_width0 % 3)<br>RGB565 : ceil(win2_vir_width0 / 2)<br>8BPP : ceil(win2_vir_width0 / 4)<br>4BPP : ceil(win2_vir_width0 / 8)<br>2BPP : ceil(win2_vir_width0 / 16)<br>1BPP : ceil(win2_vir_width0 / 32) |

**VOP\_BIG\_WIN2\_VIR2\_3**

Address: Operational Base + offset (0x019c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0140             | win2_vir_stride3<br>Number of words of Win2 Virtual3 width<br>ARGB888 : win2_vir_width3<br>RGB888 : (win2_vir_width3 * 3/4) + (win2_vir_width3 % 3)<br>RGB565 : ceil(win2_vir_width3 / 2)<br>8BPP : ceil(win2_vir_width3 / 4)<br>4BPP : ceil(win2_vir_width3 / 8)<br>2BPP : ceil(win2_vir_width3 / 16)<br>1BPP : ceil(win2_vir_width3 / 32) |
| 15:0       | RW          | 0x0140             | win2_vir_stride2<br>Number of words of Win2 Virtual2 width<br>ARGB888 : win2_vir_width2<br>RGB888 : (win2_vir_width2 * 3/4) + (win2_vir_width2 % 3)<br>RGB565 : ceil(win2_vir_width2 / 2)<br>8BPP : ceil(win2_vir_width2 / 4)<br>4BPP : ceil(win2_vir_width2 / 8)<br>2BPP : ceil(win2_vir_width2 / 16)<br>1BPP : ceil(win2_vir_width2 / 32) |

**VOP\_BIG\_WIN2\_MST0**

Address: Operational Base + offset (0x01a0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                            |
|------------|-------------|--------------------|-----------------------------------------------|
| 31:0       | RW          | 0x00000000         | win2_mst0<br>must be aligned to 8byte address |

**VOP\_BIG\_WIN2\_DSP\_INFO0**

Address: Operational Base + offset (0x01a4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                             |
|------------|-------------|--------------------|------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                       |
| 27:16      | RW          | 0x0ef              | win2_dsp_height0<br>win2_dsp_height0 = size -1 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                          |
|------------|-------------|--------------------|---------------------------------------------|
| 15:12      | RO          | 0x0                | reserved                                    |
| 11:0       | RW          | 0x13f              | win2_dsp_width0<br>win2_dsp_width = size -1 |

**VOP BIG WIN2 DSP ST0**

Address: Operational Base + offset (0x01a8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------|
| 31:29      | RO          | 0x0                | reserved                                                              |
| 28:16      | RW          | 0x000a             | win2_dsp_yst0<br>Win2 vertical start point(y) of the Panel scanning   |
| 15:13      | RO          | 0x0                | reserved                                                              |
| 12:0       | RW          | 0x000a             | win2_dsp_xst0<br>Win2 horizontal start point(x) of the Panel scanning |

**VOP BIG WIN2 COLOR KEY**

Address: Operational Base + offset (0x01ac)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                             |
|------------|-------------|--------------------|------------------------------------------------|
| 31:25      | RO          | 0x0                | reserved                                       |
| 24         | RW          | 0x0                | win2_key_en<br>1'b0 : disable<br>1'b1 : enable |
| 23:0       | RW          | 0x0000000          | win2_key_color<br>Win2 key color               |

**VOP BIG WIN2 MST1**

Address: Operational Base + offset (0x01b0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                             |
|------------|-------------|--------------------|------------------------------------------------|
| 31:0       | RW          | 0x00000000         | win2_mst1<br>*must be aligned to 8byte address |

**VOP BIG WIN2 DSP INFO1**

Address: Operational Base + offset (0x01b4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                             |
|------------|-------------|--------------------|------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                       |
| 27:16      | RW          | 0x0ef              | win2_dsp_height1<br>win2_dsp_height0 = size -1 |
| 15:12      | RO          | 0x0                | reserved                                       |
| 11:0       | RW          | 0x13f              | win2_dsp_width1<br>win2_dsp_width = size -1    |

**VOP BIG WIN2 DSP ST1**

Address: Operational Base + offset (0x01b8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------|
| 31:29      | RO          | 0x0                | reserved                                                              |
| 28:16      | RW          | 0x000a             | win2_dsp_yst1<br>Win2 vertical start point(y) of the Panel scanning   |
| 15:13      | RO          | 0x0                | reserved                                                              |
| 12:0       | RW          | 0x000a             | win2_dsp_xst1<br>Win2 horizontal start point(x) of the Panel scanning |

**VOP BIG WIN2 ALPHA CTRL**

Address: Operational Base + offset (0x01bc)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------|
| 31:12      | RO          | 0x0                | reserved                                                                         |
| 11:4       | RW          | 0x00               | win2_alpha_value<br>win2 global alpha value                                      |
| 3          | RW          | 0x0                | win2_alpha_sat_mode<br>1'b0:alpha value no change<br>1'b1:alpha=alpha + alpha[7] |
| 2          | RW          | 0x0                | win2_alpha_pre_mul<br>1'b0:Non-premultiplied alpha<br>1'b1:Premultiplied alpha   |
| 1          | RW          | 0x0                | win2_alpha_mode<br>1'b0:user-defined alpha<br>1'b1:per-pixel alpha               |
| 0          | RW          | 0x0                | win2_alpha_en<br>1'b0:disable<br>1'b1:enable                                     |

**VOP BIG WIN2 MST2**

Address: Operational Base + offset (0x01c0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                             |
|------------|-------------|--------------------|------------------------------------------------|
| 31:0       | RW          | 0x00000000         | win2_mst2<br>*must be aliased to 8byte address |

**VOP BIG WIN2 DSP INFO2**

Address: Operational Base + offset (0x01c4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                             |
|------------|-------------|--------------------|------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                       |
| 27:16      | RW          | 0x0ef              | win2_dsp_height2<br>win2_dsp_height0 = size -1 |
| 15:12      | RO          | 0x0                | reserved                                       |
| 11:0       | RW          | 0x13f              | win2_dsp_width2<br>win2_dsp_width = size -1    |

**VOP BIG WIN2 DSP ST2**

Address: Operational Base + offset (0x01c8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------|
| 31:29      | RO          | 0x0                | reserved                                                              |
| 28:16      | RW          | 0x000a             | win2_dsp_yst2<br>Win2 vertical start point(y) of the Panel scanning   |
| 15:13      | RO          | 0x0                | reserved                                                              |
| 12:0       | RW          | 0x000a             | win2_dsp_xst2<br>Win2 horizontal start point(x) of the Panel scanning |

**VOP BIG WIN2 MST3**

Address: Operational Base + offset (0x01d0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                             |
|------------|-------------|--------------------|------------------------------------------------|
| 31:0       | RW          | 0x00000000         | win2_mst3<br>*must be aliased to 8byte address |

**VOP BIG WIN2 DSP INFO3**

Address: Operational Base + offset (0x01d4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                             |
|------------|-------------|--------------------|------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                       |
| 27:16      | RW          | 0x0ef              | win2_dsp_height3<br>win2_dsp_height0 = size -1 |
| 15:12      | RO          | 0x0                | reserved                                       |
| 11:0       | RW          | 0x13f              | win2_dsp_width3<br>win2_dsp_width = size -1    |

**VOP BIG WIN2 DSP ST3**

Address: Operational Base + offset (0x01d8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------|
| 31:29      | RO          | 0x0                | reserved                                                              |
| 28:16      | RW          | 0x000a             | win2_dsp_yst3<br>Win2 vertical start point(y) of the Panel scanning   |
| 15:13      | RO          | 0x0                | reserved                                                              |
| 12:0       | RW          | 0x000a             | win2_dsp_xst3<br>Win2 horizontal start point(x) of the Panel scanning |

**VOP BIG BLANKING VALUE**

Address: Operational Base + offset (0x01f4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                          |
|------------|-------------|--------------------|-------------------------------------------------------------|
| 31:25      | RO          | 0x0                | reserved                                                    |
| 24         | RW          | 0x0                | blanking_value_config_en<br>1'b0 : disable<br>1'b1 : enable |
| 23:0       | WO          | 0x0000000          | sw_blank_value<br>blank value                               |

**VOP BIG FLAG REG FRM VALID**

Address: Operational Base + offset (0x01f8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                         |
|------------|-------------|--------------------|--------------------------------------------|
| 31:0       | RO          | 0x00000000         | flag_reg_frm_valid<br>valid by frame start |

**VOP BIG FLAG REG**

Address: Operational Base + offset (0x01fc)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b> |
|------------|-------------|--------------------|--------------------|
| 31:0       | WO          | 0x00000000         | flag_reg           |

**VOP BIG CABC CTRL0**

Address: Operational Base + offset (0x0200)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                       |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------|
| 31:27      | RO          | 0x0                | reserved                                                                                                 |
| 26:4       | RW          | 0x0000000          | cabc_calc_pixel_num<br>cabc calc pixel numbers = x % * cabc_total_num                                    |
| 3          | RW          | 0x0                | cabc_handle_en<br>cabc control pwm                                                                       |
| 2:1        | RW          | 0x0                | pwm_config_mode<br>2'b00 : last frame pwm value<br>2'b01 : cur frame pwm value<br>2'b1x : stage by stage |
| 0          | RW          | 0x0                | cabc_en<br>1'b0 : cabc disable<br>1'b1 : cabc enable                                                     |

**VOP BIG CABC CTRL1**

Address: Operational Base + offset (0x0204)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                  |
|------------|-------------|--------------------|-----------------------------------------------------|
| 31:27      | RO          | 0x0                | reserved                                            |
| 26:4       | RW          | 0x0000000          | cabc_total_num<br>cabc totala numbers = h_vd * v_vd |
| 3:1        | RO          | 0x0                | reserved                                            |
| 0          | RW          | 0x0                | cabc_lut_en<br>cabc pwm lut enable                  |

**VOP BIG CABC CTRL2**

Address: Operational Base + offset (0x0208)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                      |
|------------|-------------|--------------------|---------------------------------------------------------|
| 31         | RW          | 0x0                | max_scale_cfg_enable<br>1'b0 : disable<br>1'b1 : enable |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------|
| 30:29      | RO          | 0x0                | reserved                                                                                                           |
| 28:20      | RW          | 0x000              | max_scale_cfg_value<br>The max scale value                                                                         |
| 19         | RW          | 0x0                | cabc_stage_up_mode<br>1'b0: mul mode<br>1'b1: add mode                                                             |
| 18:17      | RO          | 0x0                | reserved                                                                                                           |
| 16:8       | RW          | 0x000              | cabc_stage_up<br>when mul mode ,scale stage up (1~1.5 * 256).<br>when add mode ,scale stage up (0x00~0xff)         |
| 7:0        | RW          | 0x00               | cabc_stage_down<br>when mul mode ,scale stage down (0.667~1 * 256).<br>when add mode ,scale stage down (0x00~0xff) |

**VOP BIG CABC CTRL3**

Address: Operational Base + offset (0x020c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                             |
|------------|-------------|--------------------|----------------------------------------------------------------|
| 31:9       | RO          | 0x0                | reserved                                                       |
| 8          | RW          | 0x0                | cabc_global_dn_limit_en<br>cabc global scale down limit enable |
| 7:0        | RW          | 0x00               | cabc_global_dn<br>cabc global scale down value                 |

**VOP BIG CABC GAUSS LINE0\_0**

Address: Operational Base + offset (0x0210)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                     |
|------------|-------------|--------------------|----------------------------------------|
| 31:24      | RW          | 0x00               | t_line0_3<br>gauss parameter t_line0_3 |
| 23:16      | RW          | 0x00               | t_line0_2<br>gauss parameter t_line0_2 |
| 15:8       | RW          | 0x00               | t_line0_1<br>gauss parameter t_line0_1 |
| 7:0        | RW          | 0x00               | t_line0_0<br>gauss parameter t_line0_0 |

**VOP BIG CABC GAUSS LINE0\_1**

Address: Operational Base + offset (0x0214)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                     |
|------------|-------------|--------------------|----------------------------------------|
| 31:24      | RO          | 0x0                | reserved                               |
| 23:16      | RW          | 0x00               | t_line0_6<br>gauss parameter t_line0_6 |
| 15:8       | RW          | 0x00               | t_line0_5<br>gauss parameter t_line0_5 |
| 7:0        | RW          | 0x00               | t_line0_4<br>gauss parameter t_line0_4 |

**VOP BIG CABC GAUSS LINE1 0**

Address: Operational Base + offset (0x0218)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                     |
|------------|-------------|--------------------|----------------------------------------|
| 31:24      | RW          | 0x00               | t_line1_3<br>gauss parameter t_line1_3 |
| 23:16      | RW          | 0x00               | t_line1_2<br>gauss parameter t_line1_2 |
| 15:8       | RW          | 0x00               | t_line1_1<br>gauss parameter t_line1_1 |
| 7:0        | RW          | 0x00               | t_line1_0<br>gauss parameter t_line1_0 |

**VOP BIG CABC GAUSS LINE1 1**

Address: Operational Base + offset (0x021c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                     |
|------------|-------------|--------------------|----------------------------------------|
| 31:24      | RO          | 0x0                | reserved                               |
| 23:16      | RW          | 0x00               | t_line1_6<br>gauss parameter t_line1_6 |
| 15:8       | RW          | 0x00               | t_line1_5<br>gauss parameter t_line1_5 |
| 7:0        | RW          | 0x00               | t_line1_4<br>gauss parameter t_line1_4 |

**VOP BIG CABC GAUSS LINE2 0**

Address: Operational Base + offset (0x0220)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                     |
|------------|-------------|--------------------|----------------------------------------|
| 31:24      | RW          | 0x00               | t_line2_3<br>gauss parameter t_line2_3 |
| 23:16      | RW          | 0x00               | t_line2_2<br>gauss parameter t_line2_2 |
| 15:8       | RW          | 0x00               | t_line2_1<br>gauss parameter t_line2_1 |
| 7:0        | RW          | 0x00               | t_line2_0<br>gauss parameter t_line2_0 |

**VOP BIG CABC GAUSS LINE2 1**

Address: Operational Base + offset (0x0224)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                     |
|------------|-------------|--------------------|----------------------------------------|
| 31:24      | RO          | 0x0                | reserved                               |
| 23:16      | RW          | 0x00               | t_line2_6<br>gauss parameter t_line2_6 |
| 15:8       | RW          | 0x00               | t_line2_5<br>gauss parameter t_line2_5 |
| 7:0        | RW          | 0x00               | t_line2_4<br>gauss parameter t_line2_4 |

**VOP BIG PWM CTRL**

Address: Operational Base + offset (0x0230)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24      | RW          | 0x00               | rpt<br>This field defines the repeated effective periods of output waveform in one-shot mode. The value N means N+1 repeated effective periods                                                     |
| 23:16      | RW          | 0x00               | scale<br>This fields defines the scale factor applied to prescaled clock. The value N means the clock is divided by 2*N. If N is 0, it means that the clock is divided by 512(2*256)               |
| 15         | RO          | 0x0                | reserved                                                                                                                                                                                           |
| 14:12      | RW          | 0x0                | prescale<br>This field defines the prescale factor applied to input clock. The value N means that the input clock is divided by 2^N                                                                |
| 11:10      | RO          | 0x0                | reserved                                                                                                                                                                                           |
| 9          | RW          | 0x0                | clk_sel<br>1'b0: non-scaled clock is selected as PWM clock source. It means that the prescale clock is directly used as the PWM clock source<br>1'b1: scaled clock is selected as PWM clock source |
| 8          | RW          | 0x0                | lp_en<br>1'b0: disabled<br>1'b1: enabled<br>When PWM channel is inactive state and Low Power Mode is enabled, the path to PWM Clock prescale module is blocked to reduce power consumption         |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                           |
| 5          | RW          | 0x0                | output_mode<br>1'b0: left aligned mode<br>1'b1: center aligned mode                                                                                                                                |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                       |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4          | RW          | 0x0                | <p>inactive_pol<br/>This defines the output waveform polarity when PWM channel is in inactive state. The inactive state means that PWM finishes the complete waveform in one-shot mode or PWM channel is disabled.</p> <p>1'b0: negative<br/>1'b1: positive</p>                                          |
| 3          | RW          | 0x0                | <p>duty_pol<br/>This defines the polarity for duty cycle. PWM starts the output waveform with duty cycle.</p> <p>1'b0: negative<br/>1'b1: positive</p>                                                                                                                                                   |
| 2:1        | RW          | 0x0                | <p>pwm_mode<br/>2'b00: One shot mode. PWM produces the waveform within the repeated times defined by PWMx_CTRL_rpt .<br/>2'b01: Continuous mode. PWM produces the waveform continuously<br/>2'b10: Capture mode. PWM measures the cycles of high/low polarity of input waveform.<br/>2'b11: reserved</p> |
| 0          | RW          | 0x0                | <p>pwm_en<br/>1'b0: disabled<br/>1'b1: enabled. If the PWM is worked the one-shot mode, this bit will be cleared at the end of operation</p>                                                                                                                                                             |

**VOP\_BIG\_PWM\_PERIOD\_HPR**

Address: Operational Base + offset (0x0234)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | <p>pwm_period<br/>If PWM is operated at the continuous mode or one-shot mode, this value defines the period of the output waveform. Note that, if the PWM is operated at the center-aligned mode, the period should be an even one, and therefore only the bit [31:1] is taken into account and bit [0] always considered as 0.<br/>If PWM is operated at the capture mode, this value indicates the effective high polarity cycles of input waveform. This value is based on the PWM clock.<br/>The value ranges from 0 to (<math>2^{32}-1</math>)</p> |

**VOP\_BIG\_PWM\_DUTY\_LPR**

Address: Operational Base + offset (0x0238)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | <p>pwm_duty</p> <p>If PWM is operated at the continuous mode or one-shot mode, this value defines the duty cycle of the output waveform. The PWM starts the output waveform with duty cycle. Note that, if the PWM is operated at the center-aligned mode, the period should be an even one, and therefore only the [31:1] is taken into account.</p> <p>If PWM is operated at the capture mode, this value indicates the effective low polarity cycles of input waveform.</p> <p>This value is based on the PWM clock. The value ranges from 0 to (<math>2^{32}-1</math>)</p> |

**VOP\_BIG\_PWM\_CNT**

Address: Operational Base + offset (0x023c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | <p>pwm_cnt</p> <p>The 32-bit indicates current value of PWM Channel 0 counter. The counter runs at the rate of PWM clock.</p> <p>The value ranges from 0 to (<math>2^{32}-1</math>)</p> |

**VOP\_BIG\_AFBCD\_CTRL**

Address: Operational Base + offset (0x0240)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | pic_vir_width<br>afbc header virtual stride                                               |
| 15:8       | RO          | 0x0                | reserved                                                                                  |
| 7:4        | RW          | 0x0                | afbcd_format<br>4'b0000 : AFBC_R5G6B5<br>4'b0100 : AFBC_R8G8B8<br>4'b0101 : AFBC_R8G8B8A8 |
| 3          | RW          | 0x0                | rb_swap<br>1'b0:ARGB<br>1'b1:ABGR                                                         |
| 2          | RW          | 0x0                | alpha_swap<br>1'b0 : ARGB<br>1'b1 : RGBA                                                  |
| 1          | RW          | 0x0                | endian_swap<br>1'b0 : ARGB8888<br>1'b1 : BGRA8888                                         |
| 0          | RW          | 0x0                | afbcd_en<br>1'b0 : disable<br>1'b1 : enable                                               |

**VOP BIG AFBCD HDR PTR**

Address: Operational Base + offset (0x0244)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                |
|------------|-------------|--------------------|---------------------------------------------------|
| 31:0       | RW          | 0x00000000         | afbcd_hdr_ptr<br>AFBC header memory start address |

**VOP BIG AFBCD PIC SIZE**

Address: Operational Base + offset (0x0248)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                            |
|------------|-------------|--------------------|-----------------------------------------------|
| 31:16      | RW          | 0x0000             | afbcd_pic_height<br>afbc pic height , real -1 |
| 15:0       | RW          | 0x0000             | afbcd_pic_width<br>afbc pic width , real -1   |

**VOP BIG AFBCD PIC OFFSET**

Address: Operational Base + offset (0x024c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                     |
|------------|-------------|--------------------|----------------------------------------|
| 31:16      | RW          | 0x0000             | afbcd_pic_yoffset<br>AFBC pic y-offset |
| 15:0       | RW          | 0x0000             | afbcd_pic_xoffset<br>AFBC pic x-offset |

**VOP BIG AFBCD AXI CTRL**

Address: Operational Base + offset (0x0250)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:24      | RO          | 0x0                | reserved                             |
| 23:20      | RW          | 0x0                | afbcd_hdr_gather_num                 |
| 19:16      | RW          | 0x0                | afbcd_pld_outstanding_num            |
| 15:12      | RW          | 0x0                | afbcd_hdr_outstanding_num            |
| 11         | RO          | 0x0                | reserved                             |
| 10         | RW          | 0x0                | afbcd_hdr_gather_en                  |
| 9          | RW          | 0x0                | afbcd_pld_outstanding_en             |
| 8          | RW          | 0x0                | afbcd_hdr_outstanding_en             |
| 7:4        | RW          | 0x0                | afbcd_pld_rid<br>payload axi read id |
| 3:0        | RW          | 0x0                | afbcd_hdr_rid<br>header axi read id  |

**VOP BIG AFBCD DBG0**

Address: Operational Base + offset (0x0254)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                         |
|------------|-------------|--------------------|--------------------------------------------|
| 31:3       | RO          | 0x0                | reserved                                   |
| 2          | RW          | 0x0                | afbcd_dec_resp<br>afbcd decode response    |
| 1          | RW          | 0x0                | afbcd_axi_rresp<br>afbcd axi read response |
| 0          | RW          | 0x0                | afbcd_idle_n<br>afbcd idle status          |

**VOP BIG CABC LUT ADDR**

Address: Operational Base + offset (0x0400)

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

**VOP BIG HWC LUT ADDR**

Address: Operational Base + offset (0x0600)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                    |
|------------|-------------|--------------------|---------------------------------------|
| 31:24      | RO          | 0x0                | reserved                              |
| 23:0       | RW          | 0x0000000          | hwc_lut_addr<br>Field0000 Description |

**VOP BIG GAMMA LUT ADDR**

Address: Operational Base + offset (0x0a00)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b> |
|------------|-------------|--------------------|--------------------|
| 31:24      | RO          | 0x0                | reserved           |
| 23:0       | RW          | 0x0000000          | gamma_lut_addr     |

**VOP BIG MMU DTE ADDR**

Address: Operational Base + offset (0x0f00)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>              |
|------------|-------------|--------------------|---------------------------------|
| 31:0       | RW          | 0x000000000        | MMU_DTE_ADDR<br>MMU DTE address |

**VOP BIG MMU STATUS**

Address: Operational Base + offset (0x0f04)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------|
| 31:10      | RO          | 0x0                | reserved                                                            |
| 9:5        | RW          | 0x00               | PAGEFAULT_BUS_ID<br>Index of master responsible for last page fault |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------|
| 4          | RW          | 0x0                | PAGE_FAULT_IS_WRITE<br>The direction of access for last page fault:<br>0 = Read<br>1 = Write                   |
| 3          | RW          | 0x0                | MMU_IDLE<br>The MMU is idle when accesses are being translated and there are no unfinished translated accesses |
| 2          | RW          | 0x0                | STAIL_ACTIVE<br>MMU stall mode currently enabled. The mode is enabled by command                               |
| 1          | RW          | 0x0                | PAGE_FAULT_ACTIVE<br>MMU page fault mode currently enabled . The mode is enabled by command                    |
| 0          | RW          | 0x0                | PAGING_ENABLED<br>Paging is enabled                                                                            |

**VOP BIG MMU COMMAND**

Address: Operational Base + offset (0x0f08)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3       | RO          | 0x0                | reserved                                                                                                                                                                                                                                |
| 2:0        | RW          | 0x0                | MMU_CMD<br>MMU_CMD. This can be:<br>3'b000: MMU_ENABLE_PAGING<br>3'b001: MMU_DISABLE_PAGING<br>3'b010: MMU_ENABLE_STALL<br>3'b011: MMU_DISABLE_STALL<br>3'b100: MMU_ZAP_CACHE<br>3'b101: MMU_PAGE_FAULT_DONE<br>3'b110: MMU_FORCE_RESET |

**VOP BIG MMU PAGE FAULT ADDR**

Address: Operational Base + offset (0x0f0c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                            |
|------------|-------------|--------------------|-----------------------------------------------|
| 31:0       | RW          | 0x000000000        | PAGE_FAULT_ADDR<br>address of last page fault |

**VOP BIG MMU ZAP ONE LINE**

Address: Operational Base + offset (0x0f10)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------|
| 31:0       | RW          | 0x000000000        | MMU_ZAP_ONE_LINE<br>address to be invalidated from the page table cache |

**VOP BIG MMU INT RAWSTAT**

Address: Operational Base + offset (0x0f14)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>               |
|------------|-------------|--------------------|----------------------------------|
| 31:2       | RO          | 0x0                | reserved                         |
| 1          | RW          | 0x0                | READ_BUS_ERROR<br>read bus error |
| 0          | RW          | 0x0                | PAGE_FAULT<br>page fault         |

**VOP BIG MMU INT CLEAR**

Address: Operational Base + offset (0x0f18)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>               |
|------------|-------------|--------------------|----------------------------------|
| 31:2       | RO          | 0x0                | reserved                         |
| 1          | RW          | 0x0                | READ_BUS_ERROR<br>read bus error |
| 0          | RW          | 0x0                | PAGE_FAULT<br>page fault         |

**VOP BIG MMU INT MASK**

Address: Operational Base + offset (0x0f1c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>               |
|------------|-------------|--------------------|----------------------------------|
| 31:2       | RO          | 0x0                | reserved                         |
| 1          | RW          | 0x0                | READ_BUS_ERROR<br>read bus error |
| 0          | RW          | 0x0                | PAGE_FAULT<br>page fault         |

**VOP BIG MMU INT STATUS**

Address: Operational Base + offset (0x0f20)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>               |
|------------|-------------|--------------------|----------------------------------|
| 31:2       | RO          | 0x0                | reserved                         |
| 1          | RW          | 0x0                | READ_BUS_ERROR<br>read bus error |
| 0          | RW          | 0x0                | PAGE_FAULT<br>page fault         |

**VOP BIG MMU AUTO GATING**

Address: Operational Base + offset (0x0f24)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------|
| 31:2       | RO          | 0x0                | reserved                                                                            |
| 1          | RW          | 0x0                | sw_mmu_cfg_mode<br>when it is 1'b0, the mmu reg config will valid after frame start |
| 0          | RW          | 0x0                | mmu_auto_gating<br>when it is 1'b1, the mmu will auto gating it self                |

**VOP BIG MMU CFG DONE**

Address: Operational Base + offset (0x0f28)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                  |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1 | RO   | 0x0         | reserved                                                                                                                                                                                                                                     |
| 0    | RW   | 0x0         | reg_load_mmu_en<br>In the first setting of the register, the new value was saved into the mirror register.<br>When all the mmu register config finish, writing this register to enable the copyright of the mirror register to real register |

**7.5 Timing Diagram**

Fig. 7-17 VOP RGB interface timing setting



Fig. 7-18 VOP RGB Interface Timing(SDR)

## 7.6 Interface Description

### 7.6.1 VOP Outputs

VOP supports RGB, MIPI, LVDS output. VOP is suitable for different display mode by different usage, which is shown as follows.

Table 7-3 VOP Control Pins Definition

| Display mode | RGB Parallel 24-bit | RGB Parallel 18-bit | RGB Parallel 16-bit |
|--------------|---------------------|---------------------|---------------------|
| DCLK         | DCLK                | DCLK                | DCLK                |
| VSYNC        | VSYNC               | VSYNC               | VSYNC               |
| HSYNC        | HSYNC               | HSYNC               | HSYNC               |

| Display mode | RGB Parallel 24-bit | RGB Parallel 18-bit | RGB Parallel 16-bit |
|--------------|---------------------|---------------------|---------------------|
| DEN          | DEN                 | DEN                 | DEN                 |
| DATA         | DATA[23:0]          | DATA[17:0]          | DATA[15:0]          |



Fig. 7-19 VOP Display output for peripherals

## 7.7 Application Notes

### 7.7.1 DMA transfer mode

There are three DMA transfer modes for loading win0 or win1 frame data determined by following parameters(X=0,1):

dma\_burst\_length  
winX\_no\_outstanding  
winX\_gather\_en  
winX\_gather\_thres

### 7.7.2 auto outstanding transfer mode(random transfer)

When winX\_no\_outstanding is 0, multi-bursts transfer command could be sent out to AXI master interface continuously if the internal memory has enough space to store new data. The continuous random burst number is in the range of 1 to 4, mainly depending on the empty level of internal memory, dma\_burst\_length, data format and active image width.

#### 1. configured outstanding transfer mode(fixed transfer)

When winX\_gather\_en is 1, fixed-number of bursts transfer command should be sent out to AXI master interface continuously if the internal memory has enough space to store new data. The fixed-number is determined by winX\_gather\_thres. Since the internal memory size is limited, there is some restriction for the winX\_gather\_thres as follows.

Table 7-4 Gather configuration for all format

| Gather Threshold                 | dma_burst_length =2'b00(burst16) | dma_burst_length =2'b01(burst8) | dma_burst_length =2'b10(burst4) |
|----------------------------------|----------------------------------|---------------------------------|---------------------------------|
| YCbCr420<br>YCbCr422<br>YCbCr444 | 0                                | 0,1,2                           | 0,1,2,3                         |
| ARGB888<br>RGB888<br>RGB565      | 0,1,2,3                          | 0,1,2,3                         | 0,1,2,3                         |
| 8BPP                             | 0,1,2,3                          | 0,1,2,3                         | 0,1,2,3                         |

### 7.7.3 GAMMA LUT

When dsp\_lut\_en is 0, the DSP LUT data should be refreshed by software. i.e, writing dsp lut data to the internal memory with the start address DSP\_LUT\_MST. The memory size is 256x24, i.e, lower 24bits valid, and the writing data number is determined by software.

### 7.7.4 DMA control (QoS/Hurry/Outstanding)

If you want to get higher priority for VOP to access external memory when the frame data is urgent, a QoS and hurry request can be generated and sent out basing on the configured values:

```
sw_noc_qos_en: SYS_CTRL1[0]
sw_noc_qos_value: SYS_CTRL1[2:1]
sw_noc_hurry_en: SYS_CTRL1[4]
sw_noc_hurry_value: SYS_CTRL1[6:5]
sw_noc_hurry_threshold: SYS_CTRL1[11:8]
sw_axi_max_outstand_en: SYS_CTRL1[12]
sw_axi_max_outstand_num: SYS_CTRL1[20:16]
```

QoS request for higher bus priority for win1

NOC hurry for higher bus priority for VIO when win0 needs higher priority.

Max Outstanding num is configurable.

### 7.7.5 Interrupt

VOP interrupt is comprised of 14 interrupt sources:

- frame start0 interrupt
- frame start1 interrupt
- address same interrupt
- line flag0 interrupt
- line flag1 interrupt
- bus error interrupt
- Win0 empty interrupt
- Win1 empty interrupt
- Display hold interrupt
- DMA finish interrupt
- Post empty interrupt
- Post Ib almost full interrupt
- Post Ib almost empty interrupt
- MMU interrupt

Every interrupt has independent interrupt enable signal(VOP\_INT\_EN),interrupt clear signal(VOP\_INT\_CLR) and interrupt raw status signal (VOP\_INT\_STATUS).

There is only one interrupt combined with all this interrupt signals to cpu , and it high active. Dma finish interrupt is used for changing DDR frequency. This interrupt will be asserted when dma finish getting all the Pixel DATA every frame. This interrupt is asserted at the end of the frame.

Address same interrupt will be asserted at this kind of scenario that all the memory start address configured in VOP reg are same compared with the former frame. This interrupt is asserted at the beginning of frame start.

The difference between frame start0 interrupt and frame start1 interrupt is that frame start0 interrupt will be asserted every frame, while the frame start1 interrupt will be masked when all the memory start address are same.

### 7.7.6 RGB display mode

RGB display mode is used for RGB panel display. It is a continuous frames display mode.



Fig. 7-20 VOP RGB Mode Programming Flow

### 1.VOP initialization

VOP initialization should be done before turning display on.

First, AXI bus parameter (VOP\_SYS\_CTRL1) should be set for DMA transfer.

Second, display panel/interface timing should be set for display output. The registers are: VOP\_DSP\_HTOTAL\_HS\_END/ VOP\_DSP\_HACT\_ST\_END/ VOP\_DSP\_VTOTAL\_HS\_END/ VOP\_DSP\_VACT\_ST\_END/ VOP\_DSP\_VS\_ST\_END\_F1/ VOP\_DSP\_VACT\_ST\_END\_F1

### 2.Background display

Before normal display, the background display could be turn on.

First, set display output mode (VOP\_DSP\_CTRL0/1) according to display device.

Second, disable dsp\_blank mode, which would not be enable until frame synchronization.

Finally, writing '1' to "VOP\_REG\_CFG\_DONE" register then all the frame-sync registers will be enable at the beginning of next frame.

### 3.Normal display

In normal display, all the display layers' attribute could be different according display scenario. So there is a programming loop in this mode.

First, configure all the display layers' attribute registers for the change of image format, location, size, scaling factor, alpha and overlay and so on. Those register would not be enable until frame synchronization.

Finally, write 1 to "VOP\_REG\_CFG\_DONE" register then all the frame-sync registers will be enable at the beginning of next frame.

### 7.7.7 Immediately control register

There are two type registers in VOP , one is effective immediately, the other is effective by frame sync. Effective immediately registers list as follows, other registers are all effective by frame sync.

Table 7-5 effective immediately register table

| register address | description                              |
|------------------|------------------------------------------|
| 0x0008           | background                               |
| 0x0018           | All display and control signal registers |
| 0xe0~0xf4        | Frc configuration bits                   |

### 7.7.8 Output Polarity Control

There are four channel outputs(RGB HDMI LVDS MIPI , some may not support because SOC

do not have the related interface) ,every channel has its own xxx\_dclk\_en, xxx\_dclk\_pol, xxx\_hsync\_pol, xxx\_vsync\_pol, xxx\_den\_pol.

The xxx\_dclk\_en should be set to 1 when output select the xxx channel, and the other channel's xxx\_dclk\_en should be set to 0 to gate the output clk and data.

When using RGB panel, the dclk should be tied to "0" or "1" in some scenarios.

In this case, you should enable sw\_io\_pad\_clk\_sel, to tie dclk to "0". If enable rgb\_dclk\_pol at the same time, the dclk will tie to "1".

### **7.7.9 Some special control**

- The blanking value of VSYNC could be configured through reg BLANKING\_VALUE;
- The current scan line number could be read through reg\_addr 0x190;
- There is a FLAG\_REG which is readable and writable. This FLAG\_REG does not for config function , our software staff may use it in the future. After writing a meaningful 32bit value to FLAG\_REG, we can read it before frame valid through reading 0x1fc value, and can get the same value after frame valid reading 0x1f8 value;

### **7.7.10 RGB PATH**

TTL typical configuration is as follows:

```
Word32(GRF_BASE + GRF_CPIO3A_IOMUX_SEL_L) = 0x11111111 ;  
Word32(GRF_BASE + GRF_CPIO3A_IOMUX_SEL_H) = 0x11111111 ;  
Word32(GRF_BASE + GRF_CPIO3B_IOMUX_SEL_L) = 0x11111111 ;  
Word32(GRF_BASE + GRF_CPIO3B_IOMUX_SEL_H) = 0x11111111 ;  
Word32(GRF_BASE + GRF_CPIO3C_IOMUX_SEL_L) = 0x11111111 ;  
Word32(GRF_BASE + GRF_CPIO3C_IOMUX_SEL_H) = 0x11111111 ;  
Word32(GRF_BASE + GRF_CPIO3D_IOMUX_SEL_L) = 0x11111111 ;
```

## Chapter 8 Raster Graphic Acceleration(RGA)

### 8.1 Overview

RGA is a separate 2D raster graphic acceleration unit. It accelerates 2D graphics operations, such as image scaling, rotation, BitBLT, alpha blending and fading.

RGA supports the following features:

- **Data format**
  - Input data:
    - ◆ Support ARGB/RGB888/RGB565/RGB4444/RGB5551/YUV420/YUV422
    - ◆ Support YUV422SP10bit/YUV420SP10bit(YUV-8bits out)
  - Output data:
    - ◆ ARGB/RGB888/RGB565/RGB4444/RGB5551/YUV420/YUV422
  - Pixel Format conversion, BT.601/BT.709
  - Dither operation
  - Max resolution: 8192x8192 source, 4096x4096 destination
- **Scaling**
  - Down-scaling: Average filter
  - Up-scaling: Bi-cubic filter(source>2048 would use Bi-linear)
  - Arbitrary non-integer scaling ratio, from 1/8 to 8
- **Rotation**
  - 0, 90, 180, 270 degree rotation
  - x-mirror, y-mirror& rotation operation
- **BitBLT**
  - Block transfer
  - Color palette/Color fill, support with alpha
  - Transparency mode (color keying/stencil test, specified value/value range)
  - Two source BitBLT:
    - A+B=B only BitBLT, A support rotate&scale when B fixed
    - A+B=C second source (B) has same attribute with (C) plus rotation function
- **Alpha Blending**
  - New comprehensive per-pixel alpha(color/alpha channel separately)
  - Fading
  - SRC1(R2Y)&&SRC0(YUV)—alpha->DST(YUV)
- **MMU**
  - 4k/64k page size
  - Four channel: SRC/SRC1/DST/CMD, individual base address and enable control bit
  - TLB pre-fetch

## 8.2 Block Diagram



Fig. 8-1 RGA Block Diagram



Fig. 8-2 RGA2 in SOC

## 8.3 Function Description

### 8.3.1 Data Format

|                            |                                                                                               |
|----------------------------|-----------------------------------------------------------------------------------------------|
| RGB_565                    | 15 R 11 G 5 B 0                                                                               |
| ARGB_4444                  | 15 A 12 R 8 G 4 B 0                                                                           |
| RGBA_4444                  | 15 R 12 G 8 B 4 A 0                                                                           |
| ARGB_1555                  | 15 A 14 R 10 G 5 B 0                                                                          |
| RGBA_5551                  | 15 R 11 G 6 B 1 A 0                                                                           |
| ARGB_8888<br>XRGB_8888     | 31 A/X 24 R 16 G 8 B 0                                                                        |
| BGRA_8888<br>BGRX_8888     | 31 B 24 16 G R 8 A/X 0                                                                        |
| ABGR_8888<br>XBGR_8888     | 31 A/X 24 B 16 G 8 R 0                                                                        |
| RGBA_8888<br>RGBX_8888     | 31 R 24 16 G B 8 A/X 0                                                                        |
| RGB_888<br>packed          | 31 R1 24 B0 16 G0 8 R0 0<br>G2 R2 B1 G1<br>B3 G3 R3 B2                                        |
| YCbCr422-SP<br>YCbCr420-SP | 31 Y03 24 Y02 16 Y01 8 Y00 0<br>Y07 Y06 Y05 Y04<br>Cr01 Cb01 Cr00 Cb00                        |
|                            | 31 Y03 24 Y02 16 Y01 8 Y00 0<br>Y07 Y06 Y05 Y04<br>Cb03 Cb02 Cb01 Cb00<br>Cr03 Cr02 Cr01 Cr00 |

Fig. 8-3 RGA Input Data Format

All input datas (defined by SRC\_IN\_FMT/DST\_IN\_FMT) are converted to ABGR8888. The results are converted to the output data format (defined by DST\_OUT\_FMT).

### 8.3.2 Dithering

There could have dithering operation for source image when the source image format is not RGB565 and the destination format is RGB565.

The down-dithering is done using Dither Allegro.



Fig. 8-4 RGA Dither effect

### **8.3.3 Alpha mode**



$Cd = Fs0 * Cs' + Fd0 * Cd' \quad (1)$   
 (Cd – dst color, Fs0 – color src factor0, Cs' – src color', Fd0 – color dst factor0, Cd' – dst color')

Fig. 8-5 layer0 alpha blending calculate flow



$$Ad = Fs1 * As1'' + Fd1 * Ad1'' \quad (2)$$

(Ad – dst alpha, Fs1 – alpha src factor1, As1'' – src alpha'', Fd1 – alpha dst factor1, Ad1'' – dst alpha'')

Fig. 8-6 layer1 alpha blending calculate flow

### 8.3.4 Color fill

Two modes of color fill can be done by RGA: solid fill and gradient fill.



Fig. 8-7 RGA Gradient Fill

Gradient fill using following equations for ARGB calculation of every pixel in different

coordinary.

```
A_cur = (A_start + x*x_A_gradient) +y*y_A_gradient;
R_cur = (R_start + x*x_R_gradient) +y*y_R_gradient;
G_cur = (G_start + x*x_G_gradient) +y*y_G_gradient;
B_cur = (B_start + x*x_B_gradient) +y*y_B_gradient;
```

A\_start, R\_start, G\_start, B\_start is the ARGB value of start point. There are four pairs of values for horizontal and vertical gradient. Saturation operation could be enabled or disabled if the color overflows 255 or underflows 0.

### 8.3.5 Raster Operation (ROP)

Raster operation (ROP) is a Boolean operation between operands, which involve AND, OR, XOR, and NOT operations. For ROP2, operands are P (select pan) and D (Destination bitmap). For ROP3, operands are P (pattern), S (source bitmap) and D (Destination bitmap). For ROP4, operands are P (pattern), S (source bitmap), D (Destination bitmap) and MASK.

Table 8-1 RGAROP Boolean operations

| Operator | Meaning                    |
|----------|----------------------------|
| a        | Bitwise AND                |
| n        | Bitwise NOT (inverse)      |
| o        | Bitwise OR                 |
| x        | Bitwise exclusive OR (XOR) |

### 8.3.6 Scaling

The scaling operation is the imageresizing processingof source image. Scaling is done base on ARGB8888 format.

There are three scale modes: scale down (bilinear, Average); scale up(bilinear, Bi-cubic);

## 8.4 Register Description

### 8.4.1 Internal Address Mapping

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

### 8.4.2 Registers Summary

| Name                          | Offset | Size | Reset Value | Description                                                 |
|-------------------------------|--------|------|-------------|-------------------------------------------------------------|
| RGA2_SYS_CTRL                 | 0x0000 | W    | 0x00000044  | RGA system control register                                 |
| RGA2_CMD_CTRL                 | 0x0004 | W    | 0x00000000  | RGA command control register                                |
| RGA2_CMD_BASE                 | 0x0008 | W    | 0x12345678  | RGA command codes base address register                     |
| RGA2_STATUS1                  | 0x000c | W    | 0x00000000  | RGA status register                                         |
| RGA2_INT                      | 0x0010 | W    | 0x00000000  | RGA interrupt register                                      |
| RGA2_MMU_CTRL0                | 0x0014 | W    | 0x00000000  | Register0000 Description                                    |
| RGA2_MMU_CMD_BASE             | 0x0018 | W    | 0x00000000  | Register0000 Description                                    |
| RGA2_STATUS2                  | 0x001c | W    | 0x00000000  | RGA status register                                         |
| RGA2_WORK_CNT                 | 0x0020 | W    | 0x00000000  |                                                             |
| RGA2_VERSION_INFO             | 0x0028 | W    | 0x00000000  | RTL version and FPGA version information                    |
| RGA2_PERF_LATENCY_CTRL0       | 0x0040 | W    | 0x00000024  | Only exist when this IP has axi_performance monitor feature |
| RGA2_PERF_LATENCY_CTRL1       | 0x0044 | W    | 0x00000021  | Only exist when this IP has axi_performance monitor feature |
| RGA2_PERF_RD_MAX_LATENCY_NUM0 | 0x0048 | W    | 0x00000000  | Only exist when this IP has axi_performance monitor feature |

| <b>Name</b>                   | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>                                                      |
|-------------------------------|---------------|-------------|--------------------|-------------------------------------------------------------------------|
| RGA2_PERF_RD_LATENCY_SAMP_NUM | 0x004c        | W           | 0x00000000         | Only exist when this IP has axi_performance monitor feature             |
| RGA2_PERF_RD_LATENCY_ACC_SUM  | 0x0050        | W           | 0x00000000         | Only exist when this IP has axi_performance monitor feature             |
| RGA2_PERF_RD_AXI_TOT_AL_BYTE  | 0x0054        | W           | 0x00000000         | Only exist when this IP has axi_performance monitor feature             |
| RGA2_PERF_WR_AXI_TOT_AL_BYTE  | 0x0058        | W           | 0x00000000         | Only exist when this IP has axi_performance monitor feature             |
| RGA2_PERF_WORKING_CNT         | 0x005c        | W           | 0x00000000         | Only exist when this IP has axi_performance monitor feature             |
| RGA2_MODE_CTRL                | 0x0100        | W           | 0x00000000         | RGA mode control register                                               |
| RGA2_SRC_INFO                 | 0x0104        | W           | 0x00000000         | RGA source information register                                         |
| RGA2_SRC_BASE0                | 0x0108        | W           | 0x00000000         | RGA source image Y/RGB base address register                            |
| RGA2_SRC_BASE1                | 0x010c        | W           | 0x00000000         | RGA source image Cb/Cbr base address register                           |
| RGA2_SRC_BASE2                | 0x0110        | W           | 0x00000000         | RGA source image Cr base address register                               |
| RGA2_SRC_BASE3                | 0x0114        | W           | 0x00000000         | RGA source image 1 base address register                                |
| RGA2_SRC_VIR_INFO             | 0x0118        | W           | 0x00000000         | RGA source image virtual stride / RGA source image tile number register |
| RGA2_SRC_ACT_INFO             | 0x011c        | W           | 0x00000000         | RGA source image active width/height register                           |
| RGA2_SRC_X_FACTOR             | 0x0120        | W           | 0x00000000         | RGA source image horizontal scaling factor                              |
| RGA2_SRC_Y_FACTOR             | 0x0124        | W           | 0x00000000         | RGA source image vertical scaling factor                                |
| RGA2_SRC_BG_COLOR             | 0x0128        | W           | 0x00000000         | RGA source image background color                                       |
| RGA2_SRC_FG_COLOR             | 0x012c        | W           | 0x00000000         | RGA source image foreground color                                       |
| RGA2_SRC_TR_COLOR0            | 0x0130        | W           | 0x00000000         | RGA source image transparency color min value                           |
| RGA2_CP_GR_A                  | 0x0130        | W           | 0x00000000         | RGA color gradient fill step register (color fill mode)                 |
| RGA2_SRC_TR_COLOR1            | 0x0134        | W           | 0x00000000         | RGA source image transparency color max value                           |
| RGA2_CP_GR_B                  | 0x0134        | W           | 0x00000000         | RGA color gradient fill step register (color fill mode)                 |
| RGA2_DST_INFO                 | 0x0138        | W           | 0x00000000         | RGA destination format register                                         |

| Name               | Offset | Size | Reset Value | Description                                             |
|--------------------|--------|------|-------------|---------------------------------------------------------|
| RGA2_DST_BASE0     | 0x013c | W    | 0x00000000  | RGA destination image base address 0 register           |
| RGA2_DST_BASE1     | 0x0140 | W    | 0x00000000  | RGA destination image base address 1 register           |
| RGA2_DST_BASE2     | 0x0144 | W    | 0x00000000  | RGA destination image base address 2 register           |
| RGA2_DST_VIR_INFO  | 0x0148 | W    | 0x00000000  | RGA destination image virtual width/height register     |
| RGA2_DST_ACT_INFO  | 0x014c | W    | 0x00000000  | RGA destination image active width/height register      |
| RGA2_ALPHA_CTRL0   | 0x0150 | W    | 0x00000000  | Alpha control register 0                                |
| RGA2_ALPHA_CTRL1   | 0x0154 | W    | 0x00000000  | Register0000 Description                                |
| RGA2_FADING_CTRL   | 0x0158 | W    | 0x00000000  | Fading control register                                 |
| RGA2_PAT_CON       | 0x015c | W    | 0x00000000  | Pattern size/offset register                            |
| RGA2_ROP_CON0      | 0x0160 | W    | 0x00000000  | ROP code 0 control register                             |
| RGA2_CP_GR_G       | 0x0160 | W    | 0x00000000  | RGA color gradient fill step register (color fill mode) |
| RGA2_ROP_CON1      | 0x0164 | W    | 0x00000000  | ROP code 1 control register                             |
| RGA2_CP_GR_R       | 0x0164 | W    | 0x00000000  | RGA color gradient fill step register (color fill mode) |
| RGA2_MASK_BASE     | 0x0168 | W    | 0x00000000  | RGA mask base address register                          |
| RGA2_MMU_CTRL1     | 0x016c | W    | 0x00000000  | RGA MMU control register 1                              |
| RGA2_MMU_SRC_BASE  | 0x0170 | W    | 0x00000000  | RGA source MMU TLB base address                         |
| RGA2_MMU_SRC1_BASE | 0x0174 | W    | 0x00000000  | RGA source1 MMU TLB base address                        |
| RGA2_MMU_DST_BASE  | 0x0178 | W    | 0x00000000  | RGA destination MMU TLB base address                    |
| RGA2_MMU_ELS_BASE  | 0x017c | W    | 0x00000000  | RGA ELSE MMU TLB base address                           |

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

### 8.4.3 Detail Register Description

#### RGA2\_SYS\_CTRL

Address: Operational Base + offset (0x0000)

| Bit  | Attr | Reset Value | Description                                                                                                                                                             |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | RO   | 0x0         | reserved                                                                                                                                                                |
| 7    | RW   | 0x0         | sw_rst_handsave_p<br>it would save protect-rstn into initial status if long time dead in protect-rstn status. (auto clear into '0')                                     |
| 6    | RW   | 0x1         | sw_rst_protect_e<br>protect-rstn mode enable.<br>it would be ensure all axi write/read operation into completion status when sw_cclk_sreset_p or sw_aclk_sreset_p valid |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------|
| 5          | RW          | 0x0                | sw_auto_rst<br>it would auto-reset after one frame finish.<br>0: disable<br>1: enable                                    |
| 4          | RW          | 0x0                | sw_cclk_sreset_p<br>RGA core clk domain Soft reset, write '1' to this would reset the RGA engine except config registers |
| 3          | WO          | 0x0                | sw_aclk_sreset_p<br>RGA aclk domain Soft reset, write '1' to this would reset the RGA engine except config registers     |
| 2          | WO          | 0x1                | sw_auto_ckg<br>RGA auto clock gating enable bit<br>0: disable<br>1: enable                                               |
| 1          | WO          | 0x0                | sw_cmd_mode<br>RGA command mode<br>0: slave mode<br>1: master mode                                                       |
| 0          | W1C         | 0x0                | sw_cmd_op_st_p<br>Only used in passive (slave) control mode                                                              |

**RGA2 CMD CTRL**

Address: Operational Base + offset (0x0004)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:13      | RO          | 0x0                | reserved                                                                                                                                                                                                |
| 12:3       | RW          | 0x000              | sw_cmd_incr_num<br>RGA command increment number                                                                                                                                                         |
| 2          | WO          | 0x0                | sw_cmd_stop<br>RGA command stop mode<br>Command execution would stop after the current graphic operation finish if set this bit to 1                                                                    |
| 1          | WO          | 0x0                | sw_cmd_incr_valid_p<br>RGA command increment valid (Auto cleared)<br>When setting this bit,<br>1. The total cmd number would increase by the RGA_INCR_CMD_NUM.<br>2. RGA would continue running if idle |
| 0          | RW          | 0x0                | sw_cmd_line_st_p<br>RGA command line fetch start (command line reset) (Auto cleared)<br>When fetch start, the total cmd number would reset to RGA_INCR_CMD_NUM                                          |

**RGA2 CMD BASE**

Address: Operational Base + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                            |
|------------|-------------|--------------------|-----------------------------------------------|
| 31:0       | RW          | 0x12345678         | sw_cmd_base<br>RGA command codes base address |

**RGA2\_STATUS1**

Address: Operational Base + offset (0x000c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 31:20      | RO          | 0x000              | sw_cmd_total_num<br>RGA command total number             |
| 19:8       | RO          | 0x000              | sw_cmd_cur_num<br>RGA command current number             |
| 7:1        | RO          | 0x00               | Reserved<br>Reserved                                     |
| 0          | RO          | 0x0                | sw_rga_sta<br>RGA engine status<br>0: idle<br>1: working |

**RGA2\_INT**

Address: Operational Base + offset (0x0010)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                         |
|------------|-------------|--------------------|------------------------------------------------------------|
| 31:11      | RO          | 0x0                | reserved                                                   |
| 10         | RW          | 0x0                | sw_intr_af_e<br>All command finished interrupt enable      |
| 9          | RW          | 0x0                | sw_intr_mmu_e<br>MMU interrupt enable                      |
| 8          | RW          | 0x0                | sw_intr_err_e<br>Error interrupt enable                    |
| 7          | WO          | 0x0                | sw_intr_cf_clr<br>Current command finished interrupt clear |
| 6          | WO          | 0x0                | sw_intr_af_clr<br>All command finished interrupt clear     |
| 5          | WO          | 0x0                | sw_intr_mmu_clr<br>MMU interrupt clear                     |
| 4          | WO          | 0x0                | sw_intr_err_clr<br>Error interrupt clear                   |
| 3          | RO          | 0x0                | sw_intr_cf<br>Current command finished interrupt flag      |
| 2          | RO          | 0x0                | sw_intr_af<br>All command finished interrupt flag          |
| 1          | RO          | 0x0                | sw_intr_mmu<br>MMU interrupt                               |
| 0          | RO          | 0x0                | sw_intr_err<br>Error interrupt flag                        |

**RGA2\_MMU\_CTRL0**

Address: Operational Base + offset (0x0014)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------|
| 31:11      | RW          | 0x0000000          | Reserved<br>Reserved                                                                                 |
| 10:9       | RW          | 0x0                | sw_els_ch_priority<br>sw_els_ch_priority                                                             |
| 8:7        | RW          | 0x0                | sw_dst_ch_priority<br>sw_dst_ch_priority                                                             |
| 6:5        | RW          | 0x0                | sw_src1_ch_priority<br>sw_src1_ch_priority                                                           |
| 4:3        | RW          | 0x0                | sw_src_ch_priority<br>sw_src_ch_priority                                                             |
| 2          | RW          | 0x0                | sw_cmd_mmu_flush<br>RGA CMD channel MMU TLB flush:<br>Set 1 to this bit to flush MMU TLB, auto clear |
| 1          | RW          | 0x0                | sw_cmd_mmu_en<br>RGA CMD channel MMU enable<br>0: disable<br>1: enable                               |
| 0          | RW          | 0x0                | sw_mmu_page_size<br>RGA MMU Page table size<br>0: 4KB page<br>1: 64KB page                           |

**RGA2\_MMU\_CMD\_BASE**

Address: Operational Base + offset (0x0018)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                         |
|------------|-------------|--------------------|------------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                   |
| 27:0       | RW          | 0x0000000          | sw_mmu_cmd_base<br>RGA command MMU TLB base address (word) |

**RGA2\_STATUS2**

Address: Operational Base + offset (0x001c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                           |
|------------|-------------|--------------------|----------------------------------------------|
| 31:13      | RO          | 0x000000           | Reserved                                     |
| 12:11      | RO          | 0x0                | rpp_mkram_rready<br>rpp_mkram_rready         |
| 10:6       | RO          | 0x00               | dstrpp_outbuf_rready<br>dstrpp_outbuf_rready |
| 5:2        | RO          | 0x0                | srcrpp_outbuf_rready<br>dstrpp_outbuf_rready |
| 1          | RO          | 0x0                | bus_error                                    |
| 0          | RO          | 0x0                | rpp_error                                    |

**RGA2 WORK CNT**

Address: Operational Base + offset (0x0020)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                       |
|------------|-------------|--------------------|------------------------------------------|
| 31:27      | RW          | 0x00               | Reserved                                 |
| 26:0       | RO          | 0x00000000         | sw_work_cnt<br>RGA total working counter |

**RGA2 VERSION INFO**

Address: Operational Base + offset (0x0028)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                |
|------------|-------------|--------------------|---------------------------------------------------|
| 31:24      | RW          | 0x00               | major<br>used for IP structure version infomation |
| 23:20      | RW          | 0x0                | minor<br>big feature change under same structure  |
| 19:0       | RW          | 0x00000            | svnbuid<br>rtl current svn number                 |

**RGA2 PERF LATENCY CTRL0**

Address: Operational Base + offset (0x0040)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------|
| 31:20      | RO          | 0x0                | reserved                                                                                  |
| 19:8       | RW          | 0x000              | sw_rd_latency_thr                                                                         |
| 7:4        | RW          | 0x2                | sw_rd_latency_id                                                                          |
| 3          | RW          | 0x0                | sw_axi_cnt_type<br>sw_axi_cnt_type                                                        |
| 2          | RW          | 0x1                | sw_axi_perf_frm_type<br>1'b0: clear by software configuration<br>1'b1: clear by frame end |
| 1          | RW          | 0x0                | sw_axi_perf_clr_e<br>1'b0: software clear disable<br>1'b1: software clear enable          |
| 0          | RW          | 0x0                | sw_axi_perf_work_e<br>1'b0: disable<br>1'b1: enable                                       |

**RGA2 PERF LATENCY CTRL1**

Address: Operational Base + offset (0x0044)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                       |
|------------|-------------|--------------------|------------------------------------------|
| 31:12      | RO          | 0x0                | reserved                                 |
| 11:8       | RW          | 0x0                | sw_aw_count_id<br>sw_aw_count_id         |
| 7:4        | RW          | 0x2                | sw_ar_count_id<br>sw_ar_count_id         |
| 3          | RW          | 0x0                | sw_aw_cnt_id_type<br>sw_aw_cnt_id_type   |
| 2          | RW          | 0x0                | sw_ar_cnt_id_type<br>sw_ar_cnt_id_type   |
| 1:0        | RW          | 0x1                | sw_addr_align_type<br>sw_addr_align_type |

**RGA2 PERF RD MAX LATENCY NUM0**

Address: Operational Base + offset (0x0048)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>     |
|------------|-------------|--------------------|------------------------|
| 31:16      | RO          | 0x0                | reserved               |
| 15:0       | RO          | 0x0000             | rd_max_latency_num_ch0 |

**RGA2 PERF RD LATENCY SAMP NUM**

Address: Operational Base + offset (0x004c)

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

**RGA2 PERF RD LATENCY ACC SUM**

Address: Operational Base + offset (0x0050)

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

**RGA2 PERF RD AXI TOTAL BYTE**

Address: Operational Base + offset (0x0054)

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

**RGA2 PERF WR AXI TOTAL BYTE**

Address: Operational Base + offset (0x0058)

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

**RGA2 PERF WORKING CNT**

Address: Operational Base + offset (0x005c)

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

**RGA2 MODE CTRL**

Address: Operational Base + offset (0x0100)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RW          | 0x0000000          | Reserved<br>Reserved                                                                                                                                                                   |
| 7          | RW          | 0x0                | sw_intr_cf_e<br>Current command finished interrupt enable                                                                                                                              |
| 6          | RW          | 0x0                | sw_gradient_sat<br>Gradient saturation calculation mode<br>0:clip<br>1:not-clip                                                                                                        |
| 5          | RW          | 0x0                | sw_alpha_zero_key<br>ARGB888 alpha zero key mode<br>0x0000000 would be changed to<br>0x000100(RGB888)/0x0020(RGB565)for ARGB888 to<br>RGBX/RGB565 color key<br>0: disable<br>1: enable |
| 4          | RW          | 0x0                | sw_cf_rop4_pat<br>Color fill/ROP4 pattern<br>0: solid color<br>1: pattern color                                                                                                        |
| 3          | RW          | 0x0                | sw_bb_mode<br>Bitblt mode<br>0: SRC + DST => DST<br>1: SRC + SRC1 => DST                                                                                                               |
| 2:0        | RW          | 0x0                | sw_render_mode<br>RGA 2D render mode<br>000: Bitblt<br>001: Color palette<br>010: Rectangle fill<br>011: Update palette LUT/pattern ram                                                |

**RGA2\_SRC\_INFO**

Address: Operational Base + offset (0x0104)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:29      | RO          | 0x0                | reserved                                                                                                                                                   |
| 28         | RW          | 0x0                | sw_src_yuv10_round_e<br>this bit valid when RGA support yuv 10bit picture input<br>0: yuv 10bit to 8bit round disable<br>1: yuv 10bit to 8bit round enable |
| 27         | RW          | 0x0                | sw_src_yuv10_e<br>this bit valid when RGA support yuv 10bit picture input<br>0: yuv 10bit disable<br>1: yuv 10bit enable                                   |
| 26         | RW          | 0x0                | sw_vsp_mode<br>0:by-cubic<br>1:bi-linear                                                                                                                   |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 25:24      | RW          | 0x0                | sw_bic_coe_sel<br>SRC bicubic scaling coefficient select<br>00: CATROM<br>01: MITCHELL<br>10: HERMITE<br>11: B-SPLINE                                                                                             |
| 23         | RW          | 0x0                | sw_src_dither_up<br>SRC dither up enable<br>0:disable<br>1:enable                                                                                                                                                 |
| 22:19      | RW          | 0x0                | sw_src_trans_e<br>Source transparency enable bits<br>[3]: A value stencil test enable bit<br>[2]: B value stencil test enable bit<br>[1]: G value stencil test enable bit<br>[0]: R value stencil test enable bit |
| 18         | RW          | 0x0                | sw_src_trans_mode<br>Source transparency mode<br>0: normal stencil test (color key)<br>1: inverted stencil test                                                                                                   |
| 17:16      | RW          | 0x0                | sw_src_vscl_mode<br>SRC vertical scaling mode<br>00: no scaling<br>01: down-scaling<br>10: up-scaling                                                                                                             |
| 15:14      | RW          | 0x0                | sw_src_hscl_mode<br>SRC horizontal scaling mode<br>00: no scaling<br>01: down-scaling<br>10: up-scaling                                                                                                           |
| 13:12      | RW          | 0x0                | sw_src_mir_mode<br>SRC mirror mode<br>00: no mirror<br>01: x mirror<br>10: y mirror<br>11: x mirror + y mirror                                                                                                    |
| 11:10      | RW          | 0x0                | sw_src_rot_mode<br>SRC rotation mode<br>00: 0 degree<br>01: 90 degree<br>10: 180 degree<br>11: 270 degree                                                                                                         |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9:8        | RW          | 0x0                | sw_src_csc_mode<br>Source bitmap YUV2RGB conversion mode<br>00: bypass<br>01: BT.601-range0<br>10: BT.601-range1<br>11: BT.709-range0                                                                                                                                                                                                           |
| 7          | RW          | 0x0                | sw_cp_endian<br>Source Color palette endian swap<br>0: big endian<br>1: little endian                                                                                                                                                                                                                                                           |
| 6          | RW          | 0x0                | sw_src_uvswap<br>Source Cb-Cr swap<br>0: CrCb<br>1: CbCr                                                                                                                                                                                                                                                                                        |
| 5          | RW          | 0x0                | sw_src_alpha_swap<br>Source bitmap data alpha swap<br>0: ABGR<br>1: BGRA                                                                                                                                                                                                                                                                        |
| 4          | RW          | 0x0                | sw_src_rbswap<br>Source bitmap data RB swap<br>0: BGR<br>1: RGB                                                                                                                                                                                                                                                                                 |
| 3:0        | RW          | 0x0                | sw_src_fmt<br>Source bitmap data format<br>0000: ABGR888<br>0001: XBGR888<br>0010: BGR packed<br>0100: RGB565<br>0101: ARGB1555<br>0110: ARGB4444<br>1000: YUV422SP<br>1001: YUV422P<br>1010: YUV420SP<br>1011: YUV420P<br>1100: 1BPP (color palette)<br>1101: 2BPP (color palette)<br>1110: 4BPP (color palette)<br>1111: 8BPP (color palette) |

**RGA2\_SRC\_BASE0**

Address: Operational Base + offset (0x0108)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                              |
|------------|-------------|--------------------|-------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_src_base0<br>source image Y/RGB base address |

**RGA2\_SRC\_BASE1**

Address: Operational Base + offset (0x010c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_src_base1<br>source image Cb base address (YUV422/420-P)<br>source image Cb/Cr base address (YU,V422/420-SP) |

**RGA2\_SRC\_BASE2**

Address: Operational Base + offset (0x0110)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                          |
|------------|-------------|--------------------|-------------------------------------------------------------|
| 31:1       | RO          | 0x0                | reserved                                                    |
| 0          | RW          | 0x0                | sw_src_base2<br>source image Cr base address (YUV422/420-P) |

**RGA2\_SRC\_BASE3**

Address: Operational Base + offset (0x0114)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------|
| 31:1       | RO          | 0x0                | reserved                                                                 |
| 0          | RW          | 0x0                | sw_src_base3<br>source image 1 RGB base address<br>(source bitblt mode1) |

**RGA2\_SRC\_VIR\_INFO**

Address: Operational Base + offset (0x0118)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                      |
|------------|-------------|--------------------|---------------------------------------------------------|
| 31:26      | RW          | 0x00               | Reserved                                                |
| 25:16      | RW          | 0x000              | sw_mask_vir_stride<br>mask image virtual stride (words) |
| 15         | RW          | 0x0                | Reserved<br>Reserved                                    |
| 14:0       | RW          | 0x0000             | sw_src_vir_stride<br>src image virtual stride (words)   |

**RGA2\_SRC\_ACT\_INFO**

Address: Operational Base + offset (0x011c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                              |
|------------|-------------|--------------------|-------------------------------------------------|
| 31:29      | RW          | 0x0                | Reserved2<br>Reserved                           |
| 28:16      | RW          | 0x0000             | sw_src_act_height<br>source image active height |
| 15:13      | RW          | 0x0                | Reserved1<br>Reserved                           |
| 12:0       | RW          | 0x0000             | sw_src_act_width<br>source image active width   |

**RGA2\_SRC\_X\_FACTOR**

Address: Operational Base + offset (0x0120)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                               |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | sw_src_hsp_factor<br>Source image horizontal up-scaling factor<br>$=(DST\_ACT\_WIDTH/SRC\_ACT\_WIDTH) * 65536$   |
| 15:0       | RW          | 0x0000             | sw_src_hsd_factor<br>Source image horizontal down-scaling factor<br>$=(SRC\_ACT\_WIDTH/DST\_ACT\_WIDTH) * 65536$ |

**RGA2\_SRC\_Y\_FACTOR**

Address: Operational Base + offset (0x0124)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | sw_src_vsp_factor<br>Source image vertical up-scaling factor<br>$(DST\_ACT\_HEIGHT/SRC\_ACT\_HEIGHT) * 65536$   |
| 15:0       | RW          | 0x0000             | sw_src_vsd_factor<br>Source image vertical down-scaling factor<br>$(SRC\_ACT\_HEIGHT/DST\_ACT\_HEIGHT) * 65536$ |

**RGA2\_SRC\_BG\_COLOR**

Address: Operational Base + offset (0x0128)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_src_bg_color<br>Source image background color<br>("0" bit color for mono expansion.) |

**RGA2\_SRC\_FG\_COLOR**

Address: Operational Base + offset (0x012c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_src_fg_color<br>Source image foreground color<br>("1" bit color for mono expansion.)<br>Color fill color, Pan color |

**RGA2\_SRC\_TR\_COLOR**

Address: Operational Base + offset (0x0130)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                               |
|------------|-------------|--------------------|------------------------------------------------------------------|
| 31:24      | RW          | 0x00               | sw_src_trans_amin<br>source image transparency color A min value |
| 23:16      | RW          | 0x00               | sw_src_trans_bmin<br>source image transparency color B min value |
| 15:8       | RW          | 0x00               | sw_src_trans_gmin<br>source image transparency color G min value |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                               |
|------------|-------------|--------------------|------------------------------------------------------------------|
| 7:0        | RW          | 0x00               | sw_src_trans_rmin<br>source image transparency color R min value |

**RGA2 CP GR A**

Address: Operational Base + offset (0x0130)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                        |
|------------|-------------|--------------------|-----------------------------------------------------------|
| 31:16      | RW          | 0x0000             | sw_gradient_y_a<br>Y gradient value of Alpha (signed 8.8) |
| 15:0       | RW          | 0x0000             | sw_gradient_x_a<br>X gradient value of Alpha (signed 8.8) |

**RGA2 SRC TR COLOR1**

Address: Operational Base + offset (0x0134)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                               |
|------------|-------------|--------------------|------------------------------------------------------------------|
| 31:24      | RW          | 0x00               | sw_src_trans_amax<br>source image transparency color A max value |
| 23:16      | RW          | 0x00               | sw_src_trans_bmax<br>source image transparency color B max value |
| 15:8       | RW          | 0x00               | sw_src_trans_gmax<br>source image transparency color G max value |
| 7:0        | RW          | 0x00               | sw_src_trans_rmax<br>source image transparency color R max value |

**RGA2 CP GR B**

Address: Operational Base + offset (0x0134)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 31:16      | RW          | 0x0000             | sw_gradient_y_b<br>Y gradient value of Blue (signed 8.8) |
| 15:0       | RW          | 0x0000             | sw_gradient_x_b<br>X gradient value of Blue (signed 8.8) |

**RGA2 DST INFO**

Address: Operational Base + offset (0x0138)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------|
| 31:22      | RO          | 0x0                | reserved                                                                                                |
| 21         | RW          | 0x0                | sw_src1_csc_clip<br>src1 read BGR2YUV Clip mode(from 0~255 clip to 36~235)<br>1: clip enable; 0: unclip |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 20:19      | RW          | 0x0                | sw_src1_csc_mode<br>sw_dst_csc_mode<br>SRC1 read bitmap RGB2YUV conversion mode<br>00: Bypass<br>01: BT.601-range0<br>10: BT.601-range1<br>11: BT.709-range0 |
| 18         | RW          | 0x0                | sw_dst_csc_clip<br>dst write BGR2YUV Clip mode(from 0~255 clip to 36~235)<br>1: clip enable; 0: unclip                                                       |
| 17:16      | RW          | 0x0                | sw_dst_csc_mode<br>sw_dst_csc_mode<br>DST write bitmap RGB2YUV conversion mode<br>00: Bypass<br>01: BT.601-range0<br>10: BT.601-range1<br>11: BT.709-range0  |
| 15:14      | RW          | 0x0                | sw_dither_mode<br>sw_dither_mode<br>DST dither down bit mode<br>00: 888 to 666<br>01: 888 to 565<br>10: 888 to 555<br>11: 888 to 444                         |
| 13         | RW          | 0x0                | sw_dither_down<br>sw_dither_down<br>DST dither down enable<br>0:disable<br>1:enable                                                                          |
| 12         | RW          | 0x0                | sw_src1_dither_up<br>sw_src1_dither_up<br>DST/SRC1 dither up enable<br>0:disable<br>1:enable                                                                 |
| 11         | RW          | 0x0                | sw_src1_alpha_swap<br>sw_src1_alpha_swap<br>Source 1 bitmap data alpha swap<br>0: ABGR<br>1: BGRA                                                            |
| 10         | RW          | 0x0                | sw_src1_rbswap<br>sw_src1_rbswap<br>Source 1 bitmap data RB swap<br>0: BGR<br>1: RGB                                                                         |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9:7        | RW          | 0x0                | <p>sw_src1_fmt<br/>Source 1 bitmap data format<br/>000: ABGR888<br/>001: XBGR888<br/>010: BGR packed<br/>100: RGB565<br/>101: ARGB1555<br/>110: ARGB4444</p>                                                                                                                                                                                                                                      |
| 6          | RW          | 0x0                | <p>sw_dst_uvswap<br/>Destination Cb-Cr swap<br/>0: CrCb<br/>1: CbCr</p>                                                                                                                                                                                                                                                                                                                           |
| 5          | RW          | 0x0                | <p>sw_dst_alpha_swap<br/>Destination bitmap data alpha swap<br/>0: ABGR<br/>1: BGRA</p>                                                                                                                                                                                                                                                                                                           |
| 4          | RW          | 0x0                | <p>sw_dst_rbswap<br/>Destination bitmap data RB swap<br/>0: BGR<br/>1: RGB</p>                                                                                                                                                                                                                                                                                                                    |
| 3:0        | RW          | 0x0                | <p>sw_dst_fmt<br/>Destination bitmap data format<br/>0000: ABGR888<br/>0001: XBGR888<br/>0010: BGR packed<br/>0100: RGB565<br/>0101: ARGB1555<br/>0110: ARGB4444<br/>1000: YUV422SP<br/>1001: YUV422P<br/>1010: YUV420SP<br/>1011: YUV420P<br/>If RGA has yuyv output format feature:<br/>1100: YVYU422(U, LSB)<br/>1101: YVYU420(U, LSB)<br/>1110: VYUY422(Y, LSB)<br/>1111: VYUY420(Y, LSB)</p> |

**RGA2 DST BASE0**

Address: Operational Base + offset (0x013c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_dst_base0<br>destination image Y/RGB base address |

**RGA2 DST BASE1**

Address: Operational Base + offset (0x0140)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                     |
|------------|-------------|--------------------|--------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_dst_base1<br>destination image Cb/CbCr base address |

**RGA2 DST BASE2**

Address: Operational Base + offset (0x0144)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                |
|------------|-------------|--------------------|---------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_dst_base2<br>destination image Cr base address |

**RGA2 DST VIR INFO**

Address: Operational Base + offset (0x0148)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                           |
|------------|-------------|--------------------|--------------------------------------------------------------|
| 31:28      | RW          | 0x0                | Reserved2<br>Reserved                                        |
| 27:16      | RW          | 0x000              | sw_src1_vir_stride<br>source image 1 virtual stride (words)  |
| 15:12      | RW          | 0x0                | Reserved1<br>Reserved                                        |
| 11:0       | RW          | 0x000              | sw_dst_vir_stride<br>destination image virtual stride(words) |

**RGA2 DST ACT INFO**

Address: Operational Base + offset (0x014c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 31:28      | RW          | 0x0                | Reserved2<br>Reserved                                |
| 27:16      | RW          | 0x000              | sw_dst_act_height<br>Destination image active height |
| 15:12      | RW          | 0x0                | Reserved1<br>Reserved                                |
| 11:0       | RW          | 0x000              | sw_dst_act_width<br>Destination image active width   |

**RGA2 ALPHA CTRL0**

Address: Operational Base + offset (0x0150)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>   |
|------------|-------------|--------------------|----------------------|
| 31:21      | RW          | 0x000              | Reserved<br>Reserved |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------|
| 20         | RW          | 0x0                | sw_mask_endian<br>ROP4 mask endian swap<br>0: big endian<br>1: little endian        |
| 19:12      | RW          | 0x00               | sw_dst_global_alpha<br>global alpha value of DST(Agd)                               |
| 11:4       | RW          | 0x00               | sw_src_global_alpha<br>global alpha value of SRC(Ags)<br>fading value in fading mod |
| 3:2        | RW          | 0x0                | sw_rop_mode<br>ROP mode select<br>00: ROP 2<br>01: ROP 3<br>10: ROP 4               |
| 1          | RW          | 0x0                | sw_alpha_rop_sel<br>Alpha or ROP select<br>0: alpha<br>1: ROP                       |
| 0          | RW          | 0x0                | sw_alpha_rop_e<br>Alpha or ROP enable<br>0: disable<br>1: enable                    |

**RGA2 ALPHA CTRL1**

Address: Operational Base + offset (0x0154)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:30      | RW          | 0x0                | Reserved<br>Reserved                                                                                                               |
| 29         | RW          | 0x0                | sw_src_alpha_m1<br>Src Transparent/opaque of alpha channel (As1')<br>0: As<br>1: 255-As                                            |
| 28         | RW          | 0x0                | sw_dst_alpha_m1<br>Dst Transparent/opaque of alpha channel (Ad1')<br>0: Ad<br>1: 255-Ad                                            |
| 27:26      | RW          | 0x0                | sw_src_blend_m1<br>Alpha src blend mode select of alpha channel (As1_)<br>00: Ags<br>01: As1'<br>10: (As1'*Ags)>>8<br>11: reserved |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 25:24      | RW          | 0x0                | sw_dst_blend_m1<br>Alpha dst blend mode select of alpha channel(Ad1_)<br>00: Agd<br>01: Ad1'<br>10: (Ad1'*Agd)>>8<br>11: reserved  |
| 23         | RW          | 0x0                | sw_src_alpha_cal_m1<br>Alpha src calculate mode of alpha channel(As1")<br>0: As1"= As1_"" + (As1_">>>7)<br>1: As1"= As1 _"         |
| 22         | RW          | 0x0                | sw_dst_alpha_cal_m1<br>Alpha dst calculate mode of alpha channel(Ad1")<br>0: Ad1"= Ad1_"" + (Ad1_">>>7)<br>1: Ad1"= Ad1 _"         |
| 21:19      | RW          | 0x0                | w_src_factor_m1<br>Src factore mode of alpha channel(Fs1)<br>000: 0<br>001: 256<br>010: Ad1"<br>011: 256-Ad1"<br>100: As1"         |
| 18:16      | RW          | 0x0                | sw_dst_factor_m1<br>Dst factore mode of alpha channel(Fd1)<br>000: 0<br>001: 256<br>010: As1"<br>011: 256-As1"<br>100: Ad1"        |
| 15         | RW          | 0x0                | sw_src_alpha_m0<br>Src Transparent/opaque of color channel (As0')<br>0: As<br>1: 255-As                                            |
| 14         | RW          | 0x0                | sw_dst_alpha_m0<br>Dst Transparent/opaque of color channel (Ad0')<br>0: Ad<br>1: 255-Ad                                            |
| 13:12      | RW          | 0x0                | sw_src_blend_m0<br>Alpha src blend mode select of color channel (As0_)<br>00: Ags<br>01: As0'<br>10: (As0'*Ags)>>8<br>11: reserved |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 11:10      | RW          | 0x0                | sw_dst_blend_m0<br>Alpha dst blend mode select of color channel(Ad0_)<br>00: Agd<br>01: Ad0'<br>10: (Ad0'*Agd)>>8<br>11: reserved |
| 9          | RW          | 0x0                | sw_src_alpha_cal_m0<br>Alpha src calculate mode of color channel(As0'')<br>0: As0''= As0_'' + (As0_''>>7)<br>1: As0''= As0_''     |
| 8          | RW          | 0x0                | sw_dst_alpha_cal_m0<br>Alpha dst calculate mode of color channel(Ad0'')<br>0: Ad0''= Ad0_'' + (Ad0_''>>7)<br>1: Ad0''= Ad0_''     |
| 7:5        | RW          | 0x0                | sw_src_factor_m0<br>Src factore mode of color channel(Fs0)<br>000: 0<br>001: 256<br>010: Ad0''<br>011: 256-Ad0''<br>100: As0''    |
| 4:2        | RW          | 0x0                | sw_dst_factor_m0<br>Dst factore mode of color channel(Fd0)<br>000: 0<br>001: 256<br>010: As0''<br>011: 256-As0''<br>100: Ad0''    |
| 1          | RW          | 0x0                | sw_src_color_m0<br>SRC color select(Cs')<br>0: Cs<br>1: Cs * As0''                                                                |
| 0          | RW          | 0x0                | sw_dst_color_m0<br>SRC color select(Cd')<br>0: Cd<br>1: Cd * Ad0''                                                                |

**RGA2 FADING CTRL**

Address: Operational Base + offset (0x0158)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>            |
|------------|-------------|--------------------|-------------------------------|
| 31:25      | RW          | 0x00               | Reserved<br>Reserved          |
| 24         | RW          | 0x0                | sw_fading_en<br>Fading enable |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------|
| 23:16      | RW          | 0x00               | sw_fading_offset_b<br>Fading offset B value                                                 |
| 15:8       | RW          | 0x00               | sw_fading_offset_g<br>Fading offset G value<br>(Pattern total number when pattern loading)  |
| 7:0        | RW          | 0x00               | sw_fading_offset_r<br>Fading offset R value<br>(Start point of pattern ram in pattern mode) |

**RGA2 PAT CON**

Address: Operational Base + offset (0x015c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                  |
|------------|-------------|--------------------|-------------------------------------|
| 31:24      | RW          | 0x00               | sw_pat_offset_y<br>Pattern y offset |
| 23:16      | RW          | 0x00               | sw_pat_offset_x<br>Pattern x offset |
| 15:8       | RW          | 0x00               | sw_pat_height<br>Pattern height     |
| 7:0        | RW          | 0x00               | sw_pat_width<br>Pattern width       |

**RGA2 ROP CON0**

Address: Operational Base + offset (0x0160)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                        |
|------------|-------------|--------------------|-------------------------------------------|
| 31:25      | RW          | 0x00               | Reserved<br>Reserved                      |
| 24:0       | RW          | 0x00000000         | sw_rop3_code0<br>Rop3 code 0 control bits |

**RGA2 CP GR G**

Address: Operational Base + offset (0x0160)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                        |
|------------|-------------|--------------------|-----------------------------------------------------------|
| 31:16      | RW          | 0x0000             | sw_gradient_y_g<br>Y gradient value of Green (signed 8.8) |
| 15:0       | RW          | 0x0000             | sw_gradient_x_g<br>X gradient value of Green (signed 8.8) |

**RGA2 ROP CON1**

Address: Operational Base + offset (0x0164)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                        |
|------------|-------------|--------------------|-------------------------------------------|
| 31:25      | RW          | 0x00               | Reserved<br>Reserved                      |
| 24:0       | RW          | 0x00000000         | sw_rop3_code1<br>Rop3 code 1 control bits |

**RGA2 CP GR R**

Address: Operational Base + offset (0x0164)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                     |
|------------|-------------|--------------------|--------------------------------------------------------|
| 31:16      | RW          | 0x0000             | sw_gradient_y_r<br>Y gradient value of Red(signed 8.8) |
| 15:0       | RW          | 0x0000             | sw_gradient_x_r<br>X gradient value of Red(signed 8.8) |

**RGA2 MASK BASE**

Address: Operational Base + offset (0x0168)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_mask_base<br>mask base address in ROP4 mode<br>LUT/ pattern load base address |

**RGA2 MMU CTRL1**

Address: Operational Base + offset (0x016c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------|
| 31:14      | RW          | 0x00000            | Reserved<br>Reserved                                                                                                     |
| 13         | RW          | 0x0                | sw_els_mmu_flush<br>RGA ELSE channel MMU TLB flush:<br>Set 1 to this bit to flush MMU TLB, auto clear                    |
| 12         | RW          | 0x0                | sw_els_mmu_en<br>RGA ELSE channel MMU enable<br>0: disable<br>1: enable                                                  |
| 11         | RW          | 0x0                | sw_dst_mmu_prefetch_dir<br>sw_dst_mmu_prefetch_dir<br>0:forward<br>1:backward                                            |
| 10         | RW          | 0x0                | sw_dst_mmu_prefetch_en<br>sw_dst_mmu_prefetch_en<br>0:disable<br>1:enable                                                |
| 9          | RW          | 0x0                | sw_dst_mmu_flush<br>sw_dst_mmu_flush<br>RGA DST channel MMU TLB flush:<br>Set 1 to this bit to flush MMU TLB, auto clear |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------|
| 8          | RW          | 0x0                | sw_dst_mmu_en<br>sw_dst_mmu_en<br>RGA DST channel MMU enable<br>0: disable<br>1: enable                                     |
| 7          | RW          | 0x0                | sw_src1_mmu_prefetch_dir<br>sw_src1_mmu_prefetch_dir<br>0:forward<br>1:backward                                             |
| 6          | RW          | 0x0                | sw_src1_mmu_prefetch_en<br>sw_src1_mmu_prefetch_en<br>0:disable<br>1:enable                                                 |
| 5          | RW          | 0x0                | sw_src1_mmu_flush<br>sw_src1_mmu_flush<br>RGA SRC1 channel MMU TLB flush:<br>Set 1 to this bit to flush MMU TLB, auto clear |
| 4          | RW          | 0x0                | sw_src1_mmu_en<br>sw_src1_mmu_en<br>RGA SRC1 channel MMU enable<br>0: disable<br>1: enable                                  |
| 3          | RW          | 0x0                | sw_src_mmu_prefetch_dir<br>sw_src_mmu_prefetch_dir<br>0:forward<br>1:backward                                               |
| 2          | RW          | 0x0                | sw_src_mmu_prefetch_en<br>sw_src_mmu_prefetch_en<br>0:disable<br>1:enable                                                   |
| 1          | RW          | 0x0                | sw_src_mmu_flush<br>RGA SRC channel MMU TLB flush:<br>Set 1 to this bit to flush MMU TLB, auto clear                        |
| 0          | RW          | 0x0                | sw_src_mmu_en<br>RGA SRC channel MMU enable<br>0: disable<br>1: enable                                                      |

**RGA2\_MMU\_SRC\_BASE**

Address: Operational Base + offset (0x0170)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                           |
|------------|-------------|--------------------|--------------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                     |
| 27:0       | RW          | 0x00000000         | sw_mmu_src_base<br>RGA source MMU TLB base address (128-bit) |

## RGA2 MMU SRC1 BASE

Address: Operational Base + offset (0x0174)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                             |
|------------|-------------|--------------------|----------------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                       |
| 27:0       | RW          | 0x00000000         | sw_mmu_src1_base<br>RGA source1 MMU TLB base address (128-bit) |

## RGA2 MMU DST BASE

Address: Operational Base + offset (0x0178)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                          |
| 27:0       | RW          | 0x00000000         | sw_mmu_dst_base<br>RGA destination MMU TLB base address (128-bit) |

RGA2 MMU ELS BASE

Address: Operational Base + offset (0x017c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                          |
| 27:0       | RW          | 0x00000000         | sw_mmu_els_base<br>RGA destination MMU TLB base address (128-bit) |

## **8.5 Application Notes**

## **8.5.1 Register Partition**

There are two types of register in RGA. The first 8 registers (0x0 - 0x1C) are general registers for system configuration including command mode, command parameter, RGA status, general interrupts. The other registers (from 0x100) are command registers for command codes.



Fig. 8-8 RGAsoftware main register-region

## 8.5.2 Command Modes

RGA has two command modes: slave mode and master mode. In slave mode (`RGA_SYS_CTRL[1] = 1'b0`), 2D graphic command only could be run one by one. CPU set all the command registers in RGA and then start RGA running by setting `RGA_SYS_CTRL[0]` to '1'. In master mode (`RGA_SYS_CTRL[1] = 1'b1`), 2D graphic commands could be run sequentially. After setting command's number to `RGA_CMD_CTRL[12:3]`, writing '1' to `RGA_CMD_CTRL[0]` will start the command fetch, then Internal command DMA fetch commands from external command line.

Command line is a collection of several command codes with continuous address. At the first start, the command start address (RGA\_CMD\_ADDR) and command number (RGA\_CMD\_CTRL[12:3]) should be set, then write '1' to cmd\_line\_st (RGA\_CMD\_CTRL[0]) to start the command line fetch. Incremental command is supported by setting cmd\_incr\_num (RGA\_CMD\_CTRL[12:3]) and cmd\_incr\_valid (RGA\_CMD\_CTRL[1]=1'b1)



Fig. 8-9 RGA command line and command counter

### 8.5.3 Command Sync

In slave command mode, command sync is controlled by CPU.

In master command mode, user can enable the current\_cmd\_int(sw\_intr\_cf), command by command to generate a interrupt at the end point of target command operation.



Fig. 8-10 RGA command sync generation

#### **8.5.4 ColorPaletteApplication Notes**

1. Palette/LUT Load into special RAM in ELS\_BUF\_CTRL;
  2. ColorPalette/Pattern interval operations no need to initialLUT/pattern ram if LUT/patterncontentno update;

### **8.5.5 Some special application constraint**

1. The algorithm of vertical scale up: must select bicubic algorithm when source picture is smaller or equal to 2k and must select bilinear when bigger than 2k
  2. The effects that the output's definition is near 2k or 4k maybe not very well when at the scenario that the vertical side is scale up and the horizontal is scale down within range of 2% (such as: 2048x32 → 2008x64)
  3. At the scenario A+B->C, the size among the A B C has some constraint :  
A's size must be equal to C. C's size must equal to B when A+C is no rotation. C's rotation (90degree) size must equal to B1 when A+C is rotation 90 degree .



Fig. 8-11 the size constraint among A B C

4. YUV420/422-8bit virtual stride need 8byte align, xoff/yoff need 2byte algin;
5. YUV420/422-10bit virtual stride need 16byte align, not support xoff/yoff;
6. Vertical scale down or not && Horizontal Bi-cubic scale up src0 width<=2048;  
Vertical scale up && Horizontal Bi-cubic scale up src0 width<=1928;
7. Vertical scale down or not && Horizontal Bilinear scale up src0 width<=4096;  
Vertical scale up && Horizontal Bilinear scale up src0 width<=3856;

## Chapter 9 Crypto

### 9.1 Overview

Crypto is a hardware accelerator for encrypting or decrypting. It supports the most commonly used algorithm: DES/3DES, AES, SHA1, SHA256, MD5 and PKA.

The Crypto supports following features:

- Support Link List Item (LLI) DMA transfer
- Support SHA-1, SHA-256/224, SHA-512/384, MD5 with hardware padding
- Support HMAC of SHA-1, SHA-256, SHA-512, MD5 with hardware padding
- Support AES-128, AES-192, AES-256 encrypt & decrypt cipher
- Support DES & TDES cipher
- Support AES ECB/CBC/OFB/CFB/CTR/CTS/XTS/CCM/GCM/CBC-MAC/CMAC mode
- Support DES/TDES ECB/CBC/OFB/CFB mode
- Support up to 4096 bits PKA mathematical operations for RSA/ECC
- Support up to 8-channels configuration
- Support 256-bits OTP device root key hardwire calculation
- Support Up to 256 bits TRNG Output

### 9.2 Block Diagram



Fig. 9-1 Crypto Architecture

Crypto contains several modules : AHB\_Slave, DMA, CIPHER, PKA, TRNG.

#### AHB\_Slave

AHB\_Slave is used to configure registers. This module is in HCLK domain.

#### DMA

DMA is used to transfer data from external memory to RX\_FIFO, or from TX\_FIFO to external memory. DMA uses 64-bits AXI3 protocol with max burst length to 16. LLI transfer is also supported for performance and convenience consideration. This module is in ACLK domain.

#### CIPHER

CIPHER contains AES, DES/TDES and HASH engines. And it also supports various mode operations. The source data is either from RX\_FIFO , or from other engine output. The result data is sending either to TX\_FIFO, or Registers in module AHB\_Slave. This module is in CLK\_CORE domain.

### PKA

PKA is used to accelerate mathematical operations for big numbers. It supports - Modular arithmetic (addition, subtraction, multiplication and division), Regular arithmetic (addition, subtraction, multiplication and division), Modular inversion, Modular exponentiation, Logical operations (AND, OR, XOR, SHIFT). PKA has a SRAM which is used to store source , result and intermediate data for PKA operations. The software driver could use PKA operations to implement complicate calculation, such as RSA, ECC etc. It could support up to 4096 bits RSA modular exponentiation calculation. This module is in CLK\_PKA domain.

### TRNG

TRNG is used to collects random bits from the ring oscillator, up to 256 random bits per time. This module is in HCLK domain.

## 9.3 Register description

### 9.3.1 Internal Address Mapping

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

### 9.3.2 Registers Summary

| Name                     | Offset | Size | Reset Value | Description                                |
|--------------------------|--------|------|-------------|--------------------------------------------|
| CRYPTO CLK CTL           | 0x0000 | W    | 0x00000001  | Clock Control Register                     |
| CRYPTO RST CTL           | 0x0004 | W    | 0x00000000  | Reset Control Register                     |
| CRYPTO DMA INT EN        | 0x0008 | W    | 0x00000000  | DMA Interrupt Enable Register              |
| CRYPTO DMA INT ST        | 0x000c | W    | 0x00000000  | DMA Interrupt Status Register              |
| CRYPTO DMA CTL           | 0x0010 | W    | 0x00000000  | DMA Control Register                       |
| CRYPTO DMA LLI ADDR      | 0x0014 | W    | 0x00000000  | DMA LIST Start Address Register            |
| CRYPTO DMA ST            | 0x0018 | W    | 0x00000000  | DMA Status Register                        |
| CRYPTO DMA STATE         | 0x001c | W    | 0x00000000  | DMA State Register                         |
| CRYPTO DMA LLI RADDR     | 0x0020 | W    | 0x00000000  | DMA LLI Read Address Register              |
| CRYPTO DMA SRC RADD<br>R | 0x0024 | W    | 0x00000000  | DMA Source Data Read Address Register      |
| CRYPTO DMA DST WAD<br>DR | 0x0028 | W    | 0x00000000  | DMA Destination Data Read Address Register |
| CRYPTO DMA ITEM ID       | 0x002c | W    | 0x00000000  | DMA Descriptor ID Register                 |
| CRYPTO FIFO CTL          | 0x0040 | W    | 0x00000003  | FIFO Control Register                      |
| CRYPTO BC CTL            | 0x0044 | W    | 0x00000000  | Block Cipher Control Register              |
| CRYPTO HASH CTL          | 0x0048 | W    | 0x00000004  | Hash Control Register                      |
| CRYPTO CIPHER ST         | 0x004c | W    | 0x00000000  | Cipher Status Register                     |
| CRYPTO CIPHER STATE      | 0x0050 | W    | 0x00000400  | Cipher Current State Register              |
| CRYPTO CHn IV 0          | 0x0100 | W    | 0x00000000  | Channel n IV Register 0                    |
| CRYPTO CHn IV 1          | 0x0104 | W    | 0x00000000  | Channel n IV Register 1                    |
| CRYPTO CHn IV 2          | 0x0108 | W    | 0x00000000  | Channel n IV Register 2                    |
| CRYPTO CHn IV 3          | 0x010c | W    | 0x00000000  | Channel n IV Register 3                    |
| CRYPTO CHn KEY 0         | 0x0180 | W    | 0x00000000  | Channel n KEY Register 0                   |

| Name                    | Offset | Size | Reset Value | Description                      |
|-------------------------|--------|------|-------------|----------------------------------|
| CRYPTO CHn KEY 1        | 0x0184 | W    | 0x00000000  | Channel n KEY Register 1         |
| CRYPTO CHn KEY 2        | 0x0188 | W    | 0x00000000  | Channel n KEY Register 2         |
| CRYPTO CHn KEY 3        | 0x018c | W    | 0x00000000  | Channel n KEY Register 3         |
| CRYPTO CHn PKEY 0       | 0x0200 | W    | 0x00000000  | Channel n Private KEY Register 0 |
| CRYPTO CHn PKEY 1       | 0x0204 | W    | 0x00000000  | Channel n Private KEY Register 1 |
| CRYPTO CHn PKEY 2       | 0x0208 | W    | 0x00000000  | Channel n Private KEY Register 2 |
| CRYPTO CHn PKEY 3       | 0x020c | W    | 0x00000000  | Channel n Private KEY Register 3 |
| CRYPTO CHn PC LEN 0     | 0x0280 | W    | 0x00000000  | Channel n PC Length Register 0   |
| CRYPTO CHn PC LEN 1     | 0x0284 | W    | 0x00000000  | Channel n PC Length Register 1   |
| CRYPTO CHn ADA LEN 0    | 0x02c0 | W    | 0x00000000  | Channel n ADA Length Register 0  |
| CRYPTO CHn ADA LEN 1    | 0x02c4 | W    | 0x00000000  | Channel n ADA Length Register 1  |
| CRYPTO CHn IV LEN 0     | 0x0300 | W    | 0x00000000  | Channel n IV Length Register 0   |
| CRYPTO CHn TAG 0        | 0x0320 | W    | 0x00000000  | Channel n Tag Register 0         |
| CRYPTO CHn TAG 1        | 0x0324 | W    | 0x00000000  | Channel n Tag Register 1         |
| CRYPTO CHn TAG 2        | 0x0328 | W    | 0x00000000  | Channel n Tag Register 2         |
| CRYPTO CHn TAG 3        | 0x032c | W    | 0x00000000  | Channel n Tag Register 3         |
| CRYPTO HASH DOUT 0      | 0x03a0 | W    | 0x00000000  | HASH Data Output Register 0      |
| CRYPTO HASH DOUT 1      | 0x03a4 | W    | 0x00000000  | HASH Data Output Register 1      |
| CRYPTO HASH DOUT 2      | 0x03a8 | W    | 0x00000000  | HASH Data Output Register 2      |
| CRYPTO HASH DOUT 3      | 0x03ac | W    | 0x00000000  | HASH Data Output Register 3      |
| CRYPTO HASH DOUT 4      | 0x03b0 | W    | 0x00000000  | HASH Data Output Register 4      |
| CRYPTO HASH DOUT 5      | 0x03b4 | W    | 0x00000000  | HASH Data Output Register 5      |
| CRYPTO HASH DOUT 6      | 0x03b8 | W    | 0x00000000  | HASH Data Output Register 6      |
| CRYPTO HASH DOUT 7      | 0x03bc | W    | 0x00000000  | HASH Data Output Register 7      |
| CRYPTO HASH DOUT 8      | 0x03c0 | W    | 0x00000000  | HASH Data Output Register 8      |
| CRYPTO HASH DOUT 9      | 0x03c4 | W    | 0x00000000  | HASH Data Output Register 9      |
| CRYPTO HASH DOUT 10     | 0x03c8 | W    | 0x00000000  | HASH Data Output Register 10     |
| CRYPTO HASH DOUT 11     | 0x03cc | W    | 0x00000000  | HASH Data Output Register 11     |
| CRYPTO HASH DOUT 12     | 0x03d0 | W    | 0x00000000  | HASH Data Output Register 12     |
| CRYPTO HASH DOUT 13     | 0x03d4 | W    | 0x00000000  | HASH Data Output Register 13     |
| CRYPTO HASH DOUT 14     | 0x03d8 | W    | 0x00000000  | HASH Data Output Register 14     |
| CRYPTO HASH DOUT 15     | 0x03dc | W    | 0x00000000  | HASH Data Output Register 15     |
| CRYPTO TAG VALID        | 0x03e0 | W    | 0x00000000  | TAG Valid Register               |
| CRYPTO HASH VALID       | 0x03e4 | W    | 0x00000000  | HASH Output Valid Register       |
| CRYPTO VERSION          | 0x03f0 | W    | 0x00000000  | CRYPTO Version Number Register   |
| CRYPTO RNG CTL          | 0x0400 | W    | 0x0000000c  | RNG Control Register             |
| CRYPTO RNG SAMPLE COUNT | 0x0404 | W    | 0x00000000  | RNG Sample Counter Register      |
| CRYPTO RNG DOUT 0       | 0x0410 | W    | 0x00000000  | RNG Data Output Register 0       |
| CRYPTO RNG DOUT 1       | 0x0414 | W    | 0x00000000  | RNG Data Output Register 1       |
| CRYPTO RNG DOUT 2       | 0x0418 | W    | 0x00000000  | RNG Data Output Register 2       |
| CRYPTO RNG DOUT 3       | 0x041c | W    | 0x00000000  | RNG Data Output Register 3       |

| Name                 | Offset | Size | Reset Value | Description                    |
|----------------------|--------|------|-------------|--------------------------------|
| CRYPTO RNG DOUT 4    | 0x0420 | W    | 0x00000000  | RNG Data Output Register 4     |
| CRYPTO RNG DOUT 5    | 0x0424 | W    | 0x00000000  | RNG Data Output Register 5     |
| CRYPTO RNG DOUT 6    | 0x0428 | W    | 0x00000000  | RNG Data Output Register 6     |
| CRYPTO RNG DOUT 7    | 0x042c | W    | 0x00000000  | RNG Data Output Register 7     |
| CRYPTO RAM CTL       | 0x0480 | W    | 0x00000000  | RAM Control Register           |
| CRYPTO RAM ST        | 0x0484 | W    | 0x00000001  | RAM Status Register            |
| CRYPTO DEBUG CTL     | 0x04a0 | W    | 0x00000000  | PKA Debug Control Register     |
| CRYPTO DEBUG ST      | 0x04a4 | W    | 0x00000001  | PKA Debug Status Register      |
| CRYPTO DEBUG MONITOR | 0x04a8 | W    | 0x0000feef  | PKA Debug Monitor Bus Register |
| CRYPTO PKA MEM MAP0  | 0x0800 | W    | 0x00000000  | PKA Memory Map 0 Register      |
| CRYPTO PKA MEM MAP1  | 0x0804 | W    | 0x00000000  | PKA Memory Map 1 Register      |
| CRYPTO PKA MEM MAP2  | 0x0808 | W    | 0x00000000  | PKA Memory Map 2 Register      |
| CRYPTO PKA MEM MAP3  | 0x080c | W    | 0x00000000  | PKA Memory Map 3 Register      |
| CRYPTO PKA MEM MAP4  | 0x0810 | W    | 0x00000000  | PKA Memory Map 4 Register      |
| CRYPTO PKA MEM MAP5  | 0x0814 | W    | 0x00000000  | PKA Memory Map 5 Register      |
| CRYPTO PKA MEM MAP6  | 0x0818 | W    | 0x00000000  | PKA Memory Map 6 Register      |
| CRYPTO PKA MEM MAP7  | 0x081c | W    | 0x00000000  | PKA Memory Map 7 Register      |
| CRYPTO PKA MEM MAP8  | 0x0820 | W    | 0x00000000  | PKA Memory Map 8 Register      |
| CRYPTO PKA MEM MAP9  | 0x0824 | W    | 0x00000000  | PKA Memory Map 9 Register      |
| CRYPTO PKA MEM MAP10 | 0x0828 | W    | 0x00000000  | PKA Memory Map 10 Register     |
| CRYPTO PKA MEM MAP11 | 0x082c | W    | 0x00000000  | PKA Memory Map 11 Register     |
| CRYPTO PKA MEM MAP12 | 0x0830 | W    | 0x00000000  | PKA Memory Map 12 Register     |
| CRYPTO PKA MEM MAP13 | 0x0834 | W    | 0x00000000  | PKA Memory Map 13 Register     |
| CRYPTO PKA MEM MAP14 | 0x0838 | W    | 0x00000000  | PKA Memory Map 14 Register     |
| CRYPTO PKA MEM MAP15 | 0x083c | W    | 0x00000000  | PKA Memory Map 15 Register     |
| CRYPTO PKA MEM MAP16 | 0x0840 | W    | 0x00000000  | PKA Memory Map 16 Register     |
| CRYPTO PKA MEM MAP17 | 0x0844 | W    | 0x00000000  | PKA Memory Map 17 Register     |
| CRYPTO PKA MEM MAP18 | 0x0848 | W    | 0x00000000  | PKA Memory Map 18 Register     |
| CRYPTO PKA MEM MAP19 | 0x084c | W    | 0x00000000  | PKA Memory Map 19 Register     |
| CRYPTO PKA MEM MAP20 | 0x0850 | W    | 0x00000000  | PKA Memory Map 20 Register     |

| Name                    | Offset | Size | Reset Value | Description                      |
|-------------------------|--------|------|-------------|----------------------------------|
| CRYPTO PKA MEM MAP2_1   | 0x0854 | W    | 0x00000000  | PKA Memory Map 21 Register       |
| CRYPTO PKA MEM MAP2_2   | 0x0858 | W    | 0x00000000  | PKA Memory Map 22 Register       |
| CRYPTO PKA MEM MAP2_3   | 0x085c | W    | 0x00000000  | PKA Memory Map 23 Register       |
| CRYPTO PKA MEM MAP2_4   | 0x0860 | W    | 0x00000000  | PKA Memory Map 24 Register       |
| CRYPTO PKA MEM MAP2_5   | 0x0864 | W    | 0x00000000  | PKA Memory Map 25 Register       |
| CRYPTO PKA MEM MAP2_6   | 0x0868 | W    | 0x00000000  | PKA Memory Map 26 Register       |
| CRYPTO PKA MEM MAP2_7   | 0x086c | W    | 0x00000000  | PKA Memory Map 27 Register       |
| CRYPTO PKA MEM MAP2_8   | 0x0870 | W    | 0x00000000  | PKA Memory Map 28 Register       |
| CRYPTO PKA MEM MAP2_9   | 0x0874 | W    | 0x00000000  | PKA Memory Map 29 Register       |
| CRYPTO PKA MEM MAP3_0   | 0x0878 | W    | 0x00000000  | PKA Memory Map 30 Register       |
| CRYPTO PKA MEM MAP3_1   | 0x087c | W    | 0x00000000  | PKA Memory Map 31 Register       |
| CRYPTO PKA OPCODE       | 0x0880 | W    | 0x00000000  | PKA Operation Code Register      |
| CRYPTO N_NP_TO_T1_A_DDR | 0x0884 | W    | 0x000ff820  | N_NP_TO_T1_ADDR Register         |
| CRYPTO PKA STATUS       | 0x0888 | W    | 0x00000001  | PKA Status Register              |
| CRYPTO PKA SW RESET     | 0x088c | W    | 0x00000000  | software reset of PKA            |
| CRYPTO PKA L0           | 0x0890 | W    | 0x00000000  | PKA Length 0 Register            |
| CRYPTO PKA L1           | 0x0894 | W    | 0x00000000  | PKA Length 1 Register            |
| CRYPTO PKA L2           | 0x0898 | W    | 0x00000000  | PKA Length 2 Register            |
| CRYPTO PKA L3           | 0x089c | W    | 0x00000000  | PKA Length 3 Register            |
| CRYPTO PKA L4           | 0x08a0 | W    | 0x00000000  | PKA Length 4 Register            |
| CRYPTO PKA L5           | 0x08a4 | W    | 0x00000000  | PKA Length 5 Register            |
| CRYPTO PKA L6           | 0x08a8 | W    | 0x00000000  | PKA Length 6 Register            |
| CRYPTO PKA L7           | 0x08ac | W    | 0x00000000  | PKA Length 7 Register            |
| CRYPTO PKA PIPE RDY     | 0x08b0 | W    | 0x00000001  | PKA pipe is ready for new opcode |
| CRYPTO PKA DONE         | 0x08b4 | W    | 0x00000001  | PKA Done Register                |
| CRYPTO PKA MON SELECT   | 0x08b8 | W    | 0x00000000  | PKA Monitor Select Register      |
| CRYPTO PKA DEBUG REG_EN | 0x08bc | W    | 0x00000000  | PKA Debug Enable Register        |
| CRYPTO DEBUG CNT ADDR   | 0x08c0 | W    | 0x00000000  | Debug Counter Address Register   |

| Name                   | Offset | Size | Reset Value | Description                   |
|------------------------|--------|------|-------------|-------------------------------|
| CRYPTO DEBUG EXT AD DR | 0x08c4 | W    | 0x00000000  | Debug Extra Address Register  |
| CRYPTO PKA DEBUG HALT  | 0x08c8 | W    | 0x00000000  | PKA Debug Halt State Register |
| CRYPTO PKA MON READ    | 0x08d0 | W    | 0x0000feef  | PKA Monitor Read Register     |
| CRYPTO PKA INT ENA     | 0x08d4 | W    | 0x00000000  | PKA Interrupt Enable Register |
| CRYPTO PKA INT ST      | 0x08d8 | W    | 0x00000000  | PKA Interrupt Status Register |
| CRYPTO SRAM ADDR       | 0x1000 | W    | 0x00000000  | SRAM Base Address             |

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

### 9.3.3 Detail Register Description

#### CRYPTO CLK CTL

Address: Operational Base + offset (0x0000)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                     |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:17 | RO   | 0x0         | reserved                                                                                                                                                                                        |
| 16    | WO   | 0x0         | write_enable<br>When bit n=1, the corresponding bit n-16 can be written by software;<br>When bit n=0, the corresponding bit n-16 can't be written by software.                                  |
| 15:1  | RO   | 0x0         | reserved                                                                                                                                                                                        |
| 0     | RW   | 0x1         | auto_clkgate_en<br>1: enable. CRYPTO will gate unused Block Cipher and HASH module automatically to save power.<br>0: disable. Symmetric Cipher and HASH Module clock will be always available. |

#### CRYPTO RST CTL

Address: Operational Base + offset (0x0004)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:19      | RO          | 0x0                | reserved                                                                                                                                                       |
| 18:16      | RW          | 0x0                | write_enable<br>When bit n=1, the corresponding bit n-16 can be written by software;<br>When bit n=0, the corresponding bit n-16 can't be written by software. |
| 15:3       | RO          | 0x0                | reserved                                                                                                                                                       |
| 2          | RW          | 0x0                | sw_pka_reset<br>Software set this bit to start a reset to PKA module. After the reset is done, CRYPTO will clear this bit.                                     |
| 1          | RW          | 0x0                | sw_rng_reset<br>Software set this bit to start a reset to TRNG module. After the reset is done, CRYPTO will clear this bit.                                    |
| 0          | R/W SC      | 0x0                | sw_cc_reset<br>Software set this bit to start a reset to Symmetric Cipher and HASH module. After the reset is done, CRYPTO will clear this bit.                |

**CRYPTO DMA INT EN**

Address: Operational Base + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                 |
|------------|-------------|--------------------|----------------------------------------------------|
| 31:7       | RO          | 0x0                | reserved                                           |
| 6          | RW          | 0x0                | zero_len_int_en<br>1: enable ;<br>0: disable;      |
| 5          | RW          | 0x0                | list_err_int_en<br>1: enable ;<br>0: disable;      |
| 4          | RW          | 0x0                | src_err_int_en<br>1: enable ;<br>0: disable.       |
| 3          | RW          | 0x0                | dst_err_int_en<br>1: enable ;<br>0: disable;       |
| 2          | RW          | 0x0                | src_item_done_int_en<br>1: enable ;<br>0: disable. |
| 1          | RW          | 0x0                | dst_item_done_int_en<br>1: enable ;<br>0: disable. |
| 0          | RW          | 0x0                | list_done_int_en<br>1: enable ;<br>0: disable.     |

**CRYPTO DMA INT ST**

Address: Operational Base + offset (0x000c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:7       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                       |
| 6          | W1<br>C     | 0x0                | zero_len<br>Indicate that DMA has met an 0 byte source transfer length in list descriptors. After the bit is read, the application should write 1 to clear this bit for next time use.                                                                         |
| 5          | W1<br>C     | 0x0                | list_err<br>Indicate that DMA has met an error response when transfer list descriptors. The state machine will exit current transfer and then return to IDLE state. After the bit is read, the application should write 1 to clear this bit for next time use. |
| 4          | W1<br>C     | 0x0                | src_err<br>Indicate that DMA has met an error response when transfer source data. The state machine will exit current transfer and then return to IDLE state. After the bit is read, the application should write 1 to clear this bit for next time use.       |
| 3          | W1<br>C     | 0x0                | dst_err<br>Indicate that DMA has met an error response when transfer destination data. The state machine will exit current transfer and then return to IDLE state. After the bit is read, the application should write 1 to clear this bit for next time use.  |
| 2          | W1<br>C     | 0x0                | src_item_done<br>Indicate that DMA has completed a read transfers which the current list descriptor pointed to . After the bit is read, the application should write 1 to clear this bit for next time use.                                                    |
| 1          | W1<br>C     | 0x0                | dst_item_done<br>Indicate that DMA has completed a write transfers which the current list descriptor pointed to . After the bit is read, the application should write 1 to clear this bit for next time use.                                                   |
| 0          | W1<br>C     | 0x0                | list_done<br>Indicate that DMA has completed all the transfers which the list descriptors pointed to . After the bit is read, the application should write 1 to clear this bit for next time use.                                                              |

**CRYPTO DMA CTL**

Address: Operational Base + offset (0x0010)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:18      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                             |
| 17:16      | WO          | 0x0                | write_enable<br>When bit n=1, the corresponding bit n-16 can be written by software;<br>When bit n=0, the corresponding bit n-16 can't be written by software.                                                                                                                                                                       |
| 15:2       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                             |
| 1          | R/W<br>SC   | 0x0                | dma_restart<br>If DMA data for next stage is not ready, application could pause DMA by descriptor commands. DMA will stop prefetching next descriptor . The application could restart DMA by asserting this bit when DMA data for next state is ready. Crypto will continue with previous transfer, and clear the bit automatically. |
| 0          | R/W<br>SC   | 0x0                | dma_start<br>DMA asserts the bit to start DMA transfer, then Crypto will clear the bit automatically .                                                                                                                                                                                                                               |

**CRYPTO DMA LLI ADDR**

Address: Operational Base + offset (0x0014)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3       | RW          | 0x00000000         | dma_lli_addr<br>When DMA_CTL.start asserted, Crypto will read the address to get the 1'st descriptor. It should be 8-bytes align. We suggest dma_lli_addr 64-byte align for best performance consideration. |
| 2:0        | RO          | 0x0                | reserved                                                                                                                                                                                                    |

**CRYPTO DMA ST**

Address: Operational Base + offset (0x0018)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                         |
|------------|-------------|--------------------|--------------------------------------------|
| 31:1       | RO          | 0x0                | reserved                                   |
| 0          | RW          | 0x0                | dma_busy<br>1: dma busy ;<br>0: dma idle ; |

**CRYPTO DMA STATE**

Address: Operational Base + offset (0x001c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                               |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------|
| 31:6       | RO          | 0x0                | reserved                                                                                         |
| 5:4        | RO          | 0x0                | dma_lli_state<br>For debug use only.<br>00: IDLE STATE;<br>01: FETCH STATE ;<br>10: WORK STATE ; |
| 3:2        | RO          | 0x0                | dma_src_state<br>For debug use only.<br>00: IDLE STATE;<br>01: LOAD STATE ;<br>10: WORK STATE ;  |
| 1:0        | RO          | 0x0                | dma_dst_state<br>For debug use only.<br>00: IDLE STATE;<br>01: LOAD STATE ;<br>10: WORK STATE ;  |

**CRYPTO DMA LLI RADDR**

Address: Operational Base + offset (0x0020)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | dma_lli_raddr<br>For debug use only.<br>It indicates the current dma lli read address. |

**CRYPTO DMA SRC RADDR**

Address: Operational Base + offset (0x0024)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | dma_src_raddr<br>For debug use only.<br>It indicates the current dma source read address. |

**CRYPTO DMA DST WADDR**

Address: Operational Base + offset (0x0028)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | dma_dst_waddr<br>For debug use only.<br>It indicates the current dma destination write address. |

**CRYPTO DMA ITEM ID**

Address: Operational Base + offset (0x002c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                                                      |
| 7:0        | RO          | 0x00               | dma_item_id<br>For debug use only.<br>It indicates the current descriptor ID. |

**CRYPTO FIFO CTL**

Address: Operational Base + offset (0x0040)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:18      | RO          | 0x0                | reserved                                                                                                                                                       |
| 17:16      | WO          | 0x0                | write_enable<br>When bit n=1, the corresponding bit n-16 can be written by software;<br>When bit n=0, the corresponding bit n-16 can't be written by software. |
| 15:2       | RO          | 0x0                | reserved                                                                                                                                                       |
| 1          | RW          | 0x1                | dout_byteswap<br>1: little endian ;<br>0: big endian .                                                                                                         |
| 0          | RW          | 0x1                | din_byteswap<br>1: little endian ;<br>0: big endian .                                                                                                          |

**CRYPTO BC CTL**

Address: Operational Base + offset (0x0044)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:26      | RO          | 0x0                | reserved                                                                                                                                                       |
| 25:16      | WO          | 0x000              | write_enable<br>When bit n=1, the corresponding bit n-16 can be written by software;<br>When bit n=0, the corresponding bit n-16 can't be written by software. |
| 15:10      | RO          | 0x0                | reserved                                                                                                                                                       |
| 9:8        | RW          | 0x0                | bc_cipher_sel<br>00: AES ;<br>01: Reserved;<br>10: DES ;<br>11: TDES .                                                                                         |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:4        | RW          | 0x0                | <p>mode<br/>FOR AES,<br/>0: ECB ;<br/>1: CBC ;<br/>2: CTS ;<br/>3: CTR ;<br/>4: CFB ;<br/>5: OFB ;<br/>6: XTS ;<br/>7: CCM;<br/>8: GCM;<br/>9: CMAC ;<br/>A: CBC-MAC.<br/>Others: Reserved.<br/>For TDES/DES ,<br/>0: ECB ;<br/>1: CBC ;<br/>4: CFB ;<br/>5: OFB ;<br/>Others: Reserved.</p> |
| 3:2        | RW          | 0x0                | <p>key_size<br/>For AES ,<br/>00: 128 bit ;<br/>01: 192 bit ;<br/>10: 256 bit ;<br/>11: reserved.<br/>For TDES/DES, it is reserved.</p>                                                                                                                                                      |
| 1          | RW          | 0x0                | <p>decrypt<br/>1: decrypt ;<br/>0: encrypt .</p>                                                                                                                                                                                                                                             |
| 0          | RW          | 0x0                | <p>bc_enable<br/>1: enable ;<br/>0: disable .</p>                                                                                                                                                                                                                                            |

**CRYPTO HASH CTL**

Address: Operational Base + offset (0x0048)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24      | RO          | 0x0                | reserved                                                                                                                                                                |
| 23:16      | WO          | 0x00               | <p>write_enable<br/>When bit n=1, the corresponding bit n-16 can be written by software;<br/>When bit n=0, the corresponding bit n-16 can't be written by software.</p> |
| 15:8       | RO          | 0x0                | reserved                                                                                                                                                                |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:4        | RW          | 0x0                | hash_cipher_sel<br>0: SHA-1 ;<br>1: MD-5 ;<br>2: SHA-256 ;<br>3: SHA-224 ;<br>8: SHA-512 ;<br>9: SHA-384 ;<br>A: SHA-512/224 ;<br>B: SHA-512/256 ;<br>Others: Reserved. |
| 3          | RW          | 0x0                | hmac_enable<br>Crypto supports HMAC-SHA1, HMAC-SHA256, HMAC_SHA512.<br>1: enable ;<br>0: disable.                                                                       |
| 2          | RW          | 0x1                | hw_pad_enable<br>1: enable ;<br>0: disable .                                                                                                                            |
| 1          | RW          | 0x0                | hash_src_sel<br>0: from RX-FIFO ;<br>1: from TX-FIFO .                                                                                                                  |
| 0          | RW          | 0x0                | hash_enable<br>1: enable ;<br>0: disable.                                                                                                                               |

**CRYPTO CIPHER ST**

Address: Operational Base + offset (0x004c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                           |
|------------|-------------|--------------------|------------------------------------------------------------------------------|
| 31:3       | RO          | 0x0                | reserved                                                                     |
| 2          | RO          | 0x0                | otp_key_valid<br>Indicate if otp_key is valid.<br>1: valid ;<br>0: invalid . |
| 1          | RO          | 0x0                | hash_busy<br>1: busy ;<br>0: idle ;                                          |
| 0          | RO          | 0x0                | block_cipher_busy<br>1: busy ;<br>0: idle ;                                  |

**CRYPTO CIPHER STATE**

Address: Operational Base + offset (0x0050)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                     |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14:10      | RW          | 0x01               | hash_state<br>For debug use only.<br>00001: IDLE State ;<br>00010: IPAD State ;<br>00100: TEXT State;<br>01000: OPAD State;<br>10000: OPAD EXT State . |
| 9:8        | RW          | 0x0                | gcm_state<br>For debug use only.<br>00: IDLE State;<br>01: PRE State;<br>10: NA State;<br>11: PC State.                                                |
| 7:6        | RW          | 0x0                | ccm_state<br>For debug use only.<br>00: IDLE State;<br>01: PRE State;<br>10: NA State;<br>11: PC State.                                                |
| 5:4        | RW          | 0x0                | parallel_state<br>For debug use only.<br>00: IDLE State;<br>01: PRE State;<br>10: BULK State.<br>11: Reserved                                          |
| 3:2        | RW          | 0x0                | mac_state<br>For debug use only.<br>00: IDLE State;<br>01: PRE State;<br>10: BULK State.<br>11: Reserved                                               |
| 1:0        | RO          | 0x0                | serial_state<br>For debug use only.<br>00: IDLE State;<br>01: PRE State;<br>10: BULK State.<br>11: Reserved                                            |

**CRYPTO CHn IV 0**

Address: Operational Base + offset (0x0100)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                               |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | chn_iv_0<br>Channel n range from 0 to 7.<br>CHn_IV_0 address = 0x0100 + 0x10 * n .<br>For CTR Mode, IV stands for counter.<br>For XTS Mode, IV stands for tweak. |

**CRYPTO CHn IV 1**

Address: Operational Base + offset (0x0104)

| Bit  | Attr | Reset Value | Description                                                                                                                                                      |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | chn_iv_1<br>Channel n range from 0 to 7.<br>CHn_IV_1 address = 0x0104 + 0x10 * n .<br>For CTR Mode, IV stands for counter.<br>For XTS Mode, IV stands for tweak. |

**CRYPTO CHn IV 2**

Address: Operational Base + offset (0x0108)

| Bit  | Attr | Reset Value | Description                                                                                                                                                      |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | chn_iv_2<br>Channel n range from 0 to 7.<br>CHn_IV_2 address = 0x0108 + 0x10 * n .<br>For CTR Mode, IV stands for counter.<br>For XTS Mode, IV stands for tweak. |

**CRYPTO CHn IV 3**

Address: Operational Base + offset (0x010c)

| Bit  | Attr | Reset Value | Description                                                                                                                                                      |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | chn_iv_3<br>Channel n range from 0 to 7.<br>CHn_IV_3 address = 0x010c + 0x10 * n .<br>For CTR Mode, IV stands for counter.<br>For XTS Mode, IV stands for tweak. |

**CRYPTO CHn KEY 0**

Address: Operational Base + offset (0x0180)

| Bit  | Attr | Reset Value | Description                                                                          |
|------|------|-------------|--------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | chn_key_0<br>Channel n range from 0 to 7.<br>CHn_KEY_0 address = 0x0180 + 0x10 * n . |

**CRYPTO CHn KEY 1**

Address: Operational Base + offset (0x0184)

| Bit  | Attr | Reset Value | Description                                                                          |
|------|------|-------------|--------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | chn_key_1<br>Channel n range from 0 to 7.<br>CHn_KEY_1 address = 0x0184 + 0x10 * n . |

**CRYPTO CHn KEY 2**

Address: Operational Base + offset (0x0188)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | chn_key_2<br>Channel n range from 0 to 7.<br>CHn_KEY_2 address = 0x0188 + 0x10 * n . |

**CRYPTO CHn KEY 3**

Address: Operational Base + offset (0x018c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | chn_key_3<br>Channel n range from 0 to 7.<br>CHn_KEY_3 address = 0x018c + 0x10 * n . |

**CRYPTO CHn PKEY 0**

Address: Operational Base + offset (0x0200)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------|
| 31:0       | WO          | 0x00000000         | chn_pkey_0<br>Channel n range from 0 to 7.<br>CHn_PKEY_0 address = 0x0200 + 0x10 * n . |

**CRYPTO CHn PKEY 1**

Address: Operational Base + offset (0x0204)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | chn_pkey_1<br>Channel n range from 0 to 7.<br>CHn_PKEY_1 address = 0x0204 + 0x10 * n . |

**CRYPTO CHn PKEY 2**

Address: Operational Base + offset (0x0208)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | chn_pkey_2<br>Channel n range from 0 to 7.<br>CHn_PKEY_2 address = 0x0208 + 0x10 * n . |

**CRYPTO CHn PKEY 3**

Address: Operational Base + offset (0x020c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | chn_key_3<br>Channel n range from 0 to 7.<br>CHn_PKEY_3 address = 0x020c + 0x10 * n . |

**CRYPTO CHn PC LEN 0**

Address: Operational Base + offset (0x0280)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | chn_pc_len_0<br>Channel n range from 0 to 7.<br>CHn_PC_LEN_0 address = 0x0280 + 0x8 * n .<br>Length in byte unit. |

**CRYPTO CHn PC LEN 1**

Address: Operational Base + offset (0x0284)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------|
| 31:29      | RO          | 0x0                | reserved                                                                                                          |
| 28:0       | RW          | 0x00000000         | chn_pc_len_1<br>Channel n range from 0 to 7.<br>CHn_PC_LEN_1 address = 0x0284 + 0x8 * n .<br>Length in byte unit. |

**CRYPTO CHn ADA LEN 0**

Address: Operational Base + offset (0x02c0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | chn_ada_len_0<br>Channel n range from 0 to 7.<br>CHn_ADA_LEN_0 address = 0x02c0 + 0x8 * n .<br>Length in byte unit. |

**CRYPTO CHn ADA LEN 1**

Address: Operational Base + offset (0x02c4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------|
| 31:29      | RO          | 0x0                | reserved                                                                                                            |
| 28:0       | RW          | 0x00000000         | chn_ada_len_1<br>Channel n range from 0 to 7.<br>CHn_ADA_LEN_1 address = 0x02c4 + 0x8 * n .<br>Length in byte unit. |

**CRYPTO CHn IV LEN 0**

Address: Operational Base + offset (0x0300)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x0                | reserved                                                                                                                                 |
| 4:0        | RW          | 0x00               | chn_iv_len<br>Channel n range from 0 to 7.<br>CHn_IV_LEN_0 address = 0x0300 + 0x4 * n .<br>Length in byte unit. Up to 16 byte IV for GCM |

**CRYPTO CHn TAG 0**

Address: Operational Base + offset (0x0320)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                    |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | chn_tag_0<br>Channel n range from 0 to 7.<br>CHn_TAG_0 address = 0x0320 + 0x10 * n .<br>When the corresponding TAG_VALID is high, TAG value is valid. |

**CRYPTO CHn TAG 1**

Address: Operational Base + offset (0x0324)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                    |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | chn_tag_1<br>Channel n range from 0 to 7.<br>CHn_TAG_1 address = 0x0324 + 0x10 * n .<br>When the corresponding TAG_VALID is high, TAG value is valid. |

**CRYPTO CHn TAG 2**

Address: Operational Base + offset (0x0328)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                    |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | chn_tag_2<br>Channel n range from 0 to 7.<br>CHn_TAG_2 address = 0x0328 + 0x10 * n .<br>When the corresponding TAG_VALID is high, TAG value is valid. |

**CRYPTO CHn TAG 3**

Address: Operational Base + offset (0x032c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                    |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | chn_tag_3<br>Channel n range from 0 to 7.<br>CHn_TAG_3 address = 0x032c + 0x10 * n .<br>When the corresponding TAG_VALID is high, TAG value is valid. |

**CRYPTO HASH DOUT 0**

Address: Operational Base + offset (0x03a0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | hash_dout_0<br>0'th output word for all hash function, in big endian. |

**CRYPTO HASH DOUT 1**

Address: Operational Base + offset (0x03a4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | hash_dout_1<br>1'th output word for all hash function, in big endian. |

**CRYPTO HASH DOUT 2**

Address: Operational Base + offset (0x03a8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | hash_dout_2<br>2'th output word for all hash function, in big endian. |

**CRYPTO HASH DOUT 3**

Address: Operational Base + offset (0x03ac)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                     |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | hash_dout_3<br>3'th output word for all hash function, in big endian.This is MD5 last output word. HASH_DOUT_4 ~ HASH_DOUT_15 is invalid data for MD5. |

**CRYPTO HASH DOUT 4**

Address: Operational Base + offset (0x03b0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | hash_dout_4<br>4'th output word for all hash function, in big endian.This is SHA-1 last output word. HASH_DOUT_5 ~ HASH_DOUT_15 is invalid data for SHA-1. |

**CRYPTO HASH DOUT 5**

Address: Operational Base + offset (0x03b4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | hash_dout_5<br>5'th output word for all hash function, in big endian. |

**CRYPTO HASH DOUT 6**

Address: Operational Base + offset (0x03b8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | hash_dout_6<br>6'th output word for all hash function, in big endian. |

**CRYPTO HASH DOUT 7**

Address: Operational Base + offset (0x03bc)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | hash_dout_7<br>7'th output word for all hash function, in big endian.This is SHA-256/224 last output word. HASH_DOUT_8 ~ HASH_DOUT_15 is invalid data for SHA-256/224. |

**CRYPTO HASH DOUT 8**

Address: Operational Base + offset (0x03c0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | hash_dout_8<br>8'th output word for all hash function, in big endian. |

**CRYPTO HASH DOUT 9**

Address: Operational Base + offset (0x03c4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | hash_dout_9<br>9'th output word for all hash function, in big endian. |

**CRYPTO HASH DOUT 10**

Address: Operational Base + offset (0x03c8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | hash_dout_10<br>10'th output word for all hash function, in big endian. |

**CRYPTO HASH DOUT 11**

Address: Operational Base + offset (0x03cc)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | hash_dout_11<br>11'th output word for all hash function, in big endian. |

**CRYPTO HASH DOUT 12**

Address: Operational Base + offset (0x03d0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | hash_dout_12<br>12'th output word for all hash function, in big endian. |

**CRYPTO HASH DOUT 13**

Address: Operational Base + offset (0x03d4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | hash_dout_13<br>13'th output word for all hash function, in big endian. |

**CRYPTO HASH DOUT 14**

Address: Operational Base + offset (0x03d8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | hash_dout_14<br>14'th output word for all hash function, in big endian. |

**CRYPTO HASH DOUT 15**

Address: Operational Base + offset (0x03dc)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | hash_dout_15<br>15'th output word for all hash function, in big endian.This is SHA-512, SHA-384, SHA-512/224, SHA-512/256 last output word. |

**CRYPTO TAG VALID**

Address: Operational Base + offset (0x03e0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                                                                                                                                                                                                                    |
| 7          | W1<br>C     | 0x0                | ch7_tag_valid<br>When channel 7 tag calculation is finished, CRYPTO will set this bit. After the bit is read by application, it should be cleared by writing 1 to this bit.<br>1: channel 7 tag is valid ;<br>0: channel 7 tag is invalid ; |
| 6          | W1<br>C     | 0x0                | ch6_tag_valid<br>When channel 6 tag calculation is finished, CRYPTO will set this bit. After the bit is read by application, it should be cleared by writing 1 to this bit.<br>1: channel 6 tag is valid ;<br>0: channel 6 tag is invalid ; |
| 5          | W1<br>C     | 0x0                | ch5_tag_valid<br>When channel 5 tag calculation is finished, CRYPTO will set this bit. After the bit is read by application, it should be cleared by writing 1 to this bit.<br>1: channel 5 tag is valid ;<br>0: channel 5 tag is invalid ; |
| 4          | W1<br>C     | 0x0                | ch4_tag_valid<br>When channel 4 tag calculation is finished, CRYPTO will set this bit. After the bit is read by application, it should be cleared by writing 1 to this bit.<br>1: channel 4 tag is valid ;<br>0: channel 4 tag is invalid ; |
| 3          | W1<br>C     | 0x0                | ch3_tag_valid<br>When channel 3 tag calculation is finished, CRYPTO will set this bit. After the bit is read by application, it should be cleared by writing 1 to this bit.<br>1: channel 3 tag is valid ;<br>0: channel 3 tag is invalid ; |
| 2          | W1<br>C     | 0x0                | ch2_tag_valid<br>When channel 2 tag calculation is finished, CRYPTO will set this bit. After the bit is read by application, it should be cleared by writing 1 to this bit.<br>1: channel 2 tag is valid ;<br>0: channel 2 tag is invalid ; |
| 1          | W1<br>C     | 0x0                | ch1_tag_valid<br>When channel 1 tag calculation is finished, CRYPTO will set this bit. After the bit is read by application, it should be cleared by writing 1 to this bit.<br>1: channel 1 tag is valid ;<br>0: channel 1 tag is invalid ; |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0          | W1<br>C     | 0x0                | ch0_tag_valid<br>When channel 0 tag calculation is finished, CRYPTO will set this bit. After the bit is read by application, it should be cleared by writing 1 to this bit.<br>1: channel 0 tag is valid ;<br>0: channel 0 tag is invalid ; |

**CRYPTO HASH VALID**

Address: Operational Base + offset (0x03e4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x0                | reserved                                                                                                                                                                                                                |
| 0          | W1<br>C     | 0x0                | hash_valid<br>When HASH calculation is finished, CRYPTO will set this bit. After the bit is read by application, it should be cleared by writing 1 to this bit.<br>1: HASH_DOUT is valid ;<br>0: HASH_DOUT is invalid ; |

**CRYPTO VERSION**

Address: Operational Base + offset (0x03f0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                       |
|------------|-------------|--------------------|------------------------------------------|
| 31:0       | RW          | 0x00000000         | version_num<br>Version number: V1.0.0.0. |

**CRYPTO RNG CTL**

Address: Operational Base + offset (0x0400)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:22      | RO          | 0x0                | reserved                                                                                                                                                       |
| 21:16      | WO          | 0x00               | write_enable<br>When bit n=1, the corresponding bit n-16 can be written by software;<br>When bit n=0, the corresponding bit n-16 can't be written by software. |
| 15:6       | RO          | 0x0                | reserved                                                                                                                                                       |
| 5:4        | RW          | 0x0                | rng_len<br>00: 64 bit;<br>01: 128 bit;<br>10: 192 bit;<br>11: 256 bit;                                                                                         |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:2        | RW          | 0x3                | <p>ring_sel<br/>There are 4 osc rings choice to decide the rng output data.<br/>00: fastest osc ring ;<br/>01: slower than osc ring 0 ;<br/>10: slower than osc ring 1 ;<br/>11: slowest osc ring ;</p> |
| 1          | RW          | 0x0                | <p>rng_enable<br/>1: enable ;<br/>0: disable.</p>                                                                                                                                                       |
| 0          | R/W<br>SC   | 0x0                | <p>rng_start<br/>The application triggers this bit to start collect rng output data.<br/>After rng is started, CRYPTO will clear the bit automatically.<br/>1: start ;<br/>0: do nothing .</p>          |

**CRYPTO RNG SAMPLE CNT**

Address: Operational Base + offset (0x0404)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0                | reserved                                                                                                                                                                                     |
| 15:0       | RW          | 0x0000             | <p>rng_sample_cnt<br/>RNG collects osc ring output bit every rng_sample_cnt time. The value of rng_sample_cnt affects RNG output data rate, the value more bigger, the rate more slower.</p> |

**CRYPTO RNG DOUT\_0**

Address: Operational Base + offset (0x0410)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | <p>rng_dout_0<br/>The 32'th osc ring bit is captured in RNG_DOUT_0.bit31.</p> |

**CRYPTO RNG DOUT\_1**

Address: Operational Base + offset (0x0414)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | <p>rng_dout_1<br/>The 64'th osc ring bit is captured in RNG_DOUT_1.bit31. If RNG_CTL.rng_len = 0x00, the last valid bit of RNG is stored in RNG_DOUT_1.bit31, and RNG_DOUT_2 ~ RNG_DOUT_7 are invalid.</p> |

**CRYPTO RNG DOUT\_2**

Address: Operational Base + offset (0x0418)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | <p>rng_dout_2<br/>The 96'th osc ring bit is captured in RNG_DOUT_2.bit31.</p> |

**CRYPTO RNG DOUT 3**

Address: Operational Base + offset (0x041c)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                         |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | rng_dout_3<br>The 128'th osc ring bit is captured in RNG_DOUT_3.bit31. If RNG_CTL.rng_len = 0x01, the last valid bit of RNG is stored in RNG_DOUT_3.bit31, and RNG_DOUT_4 ~ RNG_DOUT_7 are invalid. |

**CRYPTO RNG DOUT 4**

Address: Operational Base + offset (0x0420)

| Bit  | Attr | Reset Value | Description                                                            |
|------|------|-------------|------------------------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | rng_dout_4<br>The 160'th osc ring bit is captured in RNG_DOUT_4.bit31. |

**CRYPTO RNG DOUT 5**

Address: Operational Base + offset (0x0424)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                        |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | rng_dout_5<br>The 192'th osc ring bit is captured in RNG_DOUT_5.bit31. If RNG_CTL.rng_len = 0x02, the last valid bit of RNG is stored in RNG_DOUT_5.bit31, and RNG_DOUT_6~ RNG_DOUT_7 are invalid. |

**CRYPTO RNG DOUT 6**

Address: Operational Base + offset (0x0428)

| Bit  | Attr | Reset Value | Description                                                            |
|------|------|-------------|------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | rng_dout_6<br>The 224'th osc ring bit is captured in RNG_DOUT_6.bit31. |

**CRYPTO RNG DOUT 7**

Address: Operational Base + offset (0x042c)

| Bit  | Attr | Reset Value | Description                                                                                                                                                |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | rng_dout_7<br>The 256'th osc ring bit is captured in RNG_DOUT_7.bit31. If RNG_CTL.rng_len = 0x03, the last valid bit of RNG is stored in RNG_DOUT_7.bit31. |

**CRYPTO RAM CTL**

Address: Operational Base + offset (0x0480)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16         | WO          | 0x0                | write_enable<br>When bit n=1, the corresponding bit n-16 can be written by software;<br>When bit n=0, the corresponding bit n-16 can't be written by software. |
| 15:1       | RO          | 0x0                | reserved                                                                                                                                                       |
| 0          | RW          | 0x0                | ram_pka_rdy<br>Indicate whether ram is controlled by PKA engine.<br>0: ram is controlled by CPU.<br>1: ram is controlled by CRYPTO PKA engine.                 |

**CRYPTO RAM ST**

Address: Operational Base + offset (0x0484)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                     |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x0                | reserved                                                                                               |
| 0          | RO          | 0x1                | clk_ram_rdy<br>Indicate whether clk_ram is stable, and ready for use.<br>0: not stable ;<br>1: stable. |

**CRYPTO DEBUG CTL**

Address: Operational Base + offset (0x04a0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:17      | RO          | 0x0                | reserved                                                                                                                                                       |
| 16         | WO          | 0x0                | write_enable<br>When bit n=1, the corresponding bit n-16 can be written by software;<br>When bit n=0, the corresponding bit n-16 can't be written by software. |
| 15:1       | RO          | 0x0                | reserved                                                                                                                                                       |
| 0          | RW          | 0x0                | pka_debug_mode<br>1: PKA is in debug mode ;<br>0: PKA is in normal mode.                                                                                       |

**CRYPTO DEBUG ST**

Address: Operational Base + offset (0x04a4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                      |
|------------|-------------|--------------------|-----------------------------------------|
| 31:1       | RO          | 0x0                | reserved                                |
| 0          | RO          | 0x1                | pka_debug_clk_en<br>For debug use only. |

**CRYPTO DEBUG MONITOR**

Address: Operational Base + offset (0x04a8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                     |
|------------|-------------|--------------------|----------------------------------------|
| 31:0       | RW          | 0x0000feef         | pka_monitor_bus<br>For debug use only. |

**CRYPTO PKA MEM MAP0**

Address: Operational Base + offset (0x0800)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                          |
|------------|-------------|--------------------|-------------------------------------------------------------|
| 31:12      | RO          | 0x0                | reserved                                                    |
| 11:2       | RW          | 0x000              | memory_map0<br>memory map 0 [11:2], bit[1:0] is stuck to 0. |
| 1:0        | RO          | 0x0                | reserved                                                    |

**CRYPTO PKA MEM MAP1**

Address: Operational Base + offset (0x0804)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                          |
|------------|-------------|--------------------|-------------------------------------------------------------|
| 31:12      | RO          | 0x0                | reserved                                                    |
| 11:2       | RW          | 0x000              | memory_map1<br>memory map 1 [11:2], bit[1:0] is stuck to 0. |
| 1:0        | RO          | 0x0                | reserved                                                    |

**CRYPTO PKA MEM MAP2**

Address: Operational Base + offset (0x0808)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                          |
|------------|-------------|--------------------|-------------------------------------------------------------|
| 31:12      | RO          | 0x0                | reserved                                                    |
| 11:2       | RW          | 0x000              | memory_map2<br>memory map 2 [11:2], bit[1:0] is stuck to 0. |
| 1:0        | RO          | 0x0                | reserved                                                    |

**CRYPTO PKA MEM MAP3**

Address: Operational Base + offset (0x080c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                          |
|------------|-------------|--------------------|-------------------------------------------------------------|
| 31:12      | RO          | 0x0                | reserved                                                    |
| 11:2       | RW          | 0x000              | memory_map3<br>memory map 3 [11:2], bit[1:0] is stuck to 0. |
| 1:0        | RO          | 0x0                | reserved                                                    |

**CRYPTO PKA MEM MAP4**

Address: Operational Base + offset (0x0810)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                          |
|------------|-------------|--------------------|-------------------------------------------------------------|
| 31:12      | RO          | 0x0                | reserved                                                    |
| 11:2       | RW          | 0x000              | memory_map4<br>memory map 4 [11:2], bit[1:0] is stuck to 0. |
| 1:0        | RO          | 0x0                | reserved                                                    |

**CRYPTO PKA MEM MAP5**

Address: Operational Base + offset (0x0814)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                          |
|------------|-------------|--------------------|-------------------------------------------------------------|
| 31:12      | RO          | 0x0                | reserved                                                    |
| 11:2       | RW          | 0x000              | memory_map5<br>memory map 5 [11:2], bit[1:0] is stuck to 0. |
| 1:0        | RO          | 0x0                | reserved                                                    |

**CRYPTO PKA MEM MAP6**

Address: Operational Base + offset (0x0818)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                          |
|------------|-------------|--------------------|-------------------------------------------------------------|
| 31:12      | RO          | 0x0                | reserved                                                    |
| 11:2       | RW          | 0x000              | memory_map6<br>memory map 6 [11:2], bit[1:0] is stuck to 0. |
| 1:0        | RO          | 0x0                | reserved                                                    |

**CRYPTO PKA MEM MAP7**

Address: Operational Base + offset (0x081c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                          |
|------------|-------------|--------------------|-------------------------------------------------------------|
| 31:12      | RO          | 0x0                | reserved                                                    |
| 11:2       | RW          | 0x000              | memory_map7<br>memory map 7 [11:2], bit[1:0] is stuck to 0. |
| 1:0        | RO          | 0x0                | reserved                                                    |

**CRYPTO PKA MEM MAP8**

Address: Operational Base + offset (0x0820)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                          |
|------------|-------------|--------------------|-------------------------------------------------------------|
| 31:12      | RO          | 0x0                | reserved                                                    |
| 11:2       | RW          | 0x000              | memory_map8<br>memory map 8 [11:2], bit[1:0] is stuck to 0. |
| 1:0        | RO          | 0x0                | reserved                                                    |

**CRYPTO PKA MEM MAP9**

Address: Operational Base + offset (0x0824)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                          |
|------------|-------------|--------------------|-------------------------------------------------------------|
| 31:12      | RO          | 0x0                | reserved                                                    |
| 11:2       | RW          | 0x000              | memory_map9<br>memory map 9 [11:2], bit[1:0] is stuck to 0. |
| 1:0        | RO          | 0x0                | reserved                                                    |

**CRYPTO PKA MEM MAP10**

Address: Operational Base + offset (0x0828)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                            |
|------------|-------------|--------------------|---------------------------------------------------------------|
| 31:12      | RO          | 0x0                | reserved                                                      |
| 11:2       | RW          | 0x000              | memory_map10<br>memory map 10 [11:2], bit[1:0] is stuck to 0. |
| 1:0        | RO          | 0x0                | reserved                                                      |

**CRYPTO PKA MEM MAP11**

Address: Operational Base + offset (0x082c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                            |
|------------|-------------|--------------------|---------------------------------------------------------------|
| 31:12      | RO          | 0x0                | reserved                                                      |
| 11:2       | RW          | 0x000              | memory_map11<br>memory map 11 [11:2], bit[1:0] is stuck to 0. |
| 1:0        | RO          | 0x0                | reserved                                                      |

**CRYPTO PKA MEM MAP12**

Address: Operational Base + offset (0x0830)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                            |
|------------|-------------|--------------------|---------------------------------------------------------------|
| 31:12      | RO          | 0x0                | reserved                                                      |
| 11:2       | RW          | 0x000              | memory_map12<br>memory map 12 [11:2], bit[1:0] is stuck to 0. |
| 1:0        | RO          | 0x0                | reserved                                                      |

**CRYPTO PKA MEM MAP13**

Address: Operational Base + offset (0x0834)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                            |
|------------|-------------|--------------------|---------------------------------------------------------------|
| 31:12      | RO          | 0x0                | reserved                                                      |
| 11:2       | RW          | 0x000              | memory_map13<br>memory map 13 [11:2], bit[1:0] is stuck to 0. |
| 1:0        | RO          | 0x0                | reserved                                                      |

**CRYPTO PKA MEM MAP14**

Address: Operational Base + offset (0x0838)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                            |
|------------|-------------|--------------------|---------------------------------------------------------------|
| 31:12      | RO          | 0x0                | reserved                                                      |
| 11:2       | RW          | 0x000              | memory_map14<br>memory map 14 [11:2], bit[1:0] is stuck to 0. |
| 1:0        | RO          | 0x0                | reserved                                                      |

**CRYPTO PKA MEM MAP15**

Address: Operational Base + offset (0x083c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                            |
|------------|-------------|--------------------|---------------------------------------------------------------|
| 31:12      | RO          | 0x0                | reserved                                                      |
| 11:2       | RW          | 0x000              | memory_map15<br>memory map 15 [11:2], bit[1:0] is stuck to 0. |
| 1:0        | RO          | 0x0                | reserved                                                      |

**CRYPTO PKA MEM MAP16**

Address: Operational Base + offset (0x0840)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                            |
|------------|-------------|--------------------|---------------------------------------------------------------|
| 31:12      | RO          | 0x0                | reserved                                                      |
| 11:2       | RW          | 0x000              | memory_map16<br>memory map 16 [11:2], bit[1:0] is stuck to 0. |
| 1:0        | RO          | 0x0                | reserved                                                      |

**CRYPTO PKA MEM MAP17**

Address: Operational Base + offset (0x0844)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                            |
|------------|-------------|--------------------|---------------------------------------------------------------|
| 31:12      | RO          | 0x0                | reserved                                                      |
| 11:2       | RW          | 0x000              | memory_map17<br>memory map 17 [11:2], bit[1:0] is stuck to 0. |
| 1:0        | RO          | 0x0                | reserved                                                      |

**CRYPTO PKA MEM MAP18**

Address: Operational Base + offset (0x0848)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                            |
|------------|-------------|--------------------|---------------------------------------------------------------|
| 31:12      | RO          | 0x0                | reserved                                                      |
| 11:2       | RW          | 0x000              | memory_map18<br>memory map 18 [11:2], bit[1:0] is stuck to 0. |
| 1:0        | RO          | 0x0                | reserved                                                      |

**CRYPTO PKA MEM MAP19**

Address: Operational Base + offset (0x084c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                            |
|------------|-------------|--------------------|---------------------------------------------------------------|
| 31:12      | RO          | 0x0                | reserved                                                      |
| 11:2       | RW          | 0x000              | memory_map19<br>memory map 19 [11:2], bit[1:0] is stuck to 0. |
| 1:0        | RO          | 0x0                | reserved                                                      |

**CRYPTO PKA MEM MAP20**

Address: Operational Base + offset (0x0850)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                            |
|------------|-------------|--------------------|---------------------------------------------------------------|
| 31:12      | RO          | 0x0                | reserved                                                      |
| 11:2       | RW          | 0x000              | memory_map20<br>memory map 20 [11:2], bit[1:0] is stuck to 0. |
| 1:0        | RO          | 0x0                | reserved                                                      |

**CRYPTO PKA MEM MAP21**

Address: Operational Base + offset (0x0854)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                            |
|------------|-------------|--------------------|---------------------------------------------------------------|
| 31:12      | RO          | 0x0                | reserved                                                      |
| 11:2       | RW          | 0x000              | memory_map21<br>memory map 21 [11:2], bit[1:0] is stuck to 0. |
| 1:0        | RO          | 0x0                | reserved                                                      |

**CRYPTO PKA MEM MAP22**

Address: Operational Base + offset (0x0858)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                            |
|------------|-------------|--------------------|---------------------------------------------------------------|
| 31:12      | RO          | 0x0                | reserved                                                      |
| 11:2       | RW          | 0x000              | memory_map22<br>memory map 22 [11:2], bit[1:0] is stuck to 0. |
| 1:0        | RO          | 0x0                | reserved                                                      |

**CRYPTO PKA MEM MAP23**

Address: Operational Base + offset (0x085c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                            |
|------------|-------------|--------------------|---------------------------------------------------------------|
| 31:12      | RO          | 0x0                | reserved                                                      |
| 11:2       | RW          | 0x000              | memory_map23<br>memory map 23 [11:2], bit[1:0] is stuck to 0. |
| 1:0        | RO          | 0x0                | reserved                                                      |

**CRYPTO PKA MEM MAP24**

Address: Operational Base + offset (0x0860)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                            |
|------------|-------------|--------------------|---------------------------------------------------------------|
| 31:12      | RO          | 0x0                | reserved                                                      |
| 11:2       | RW          | 0x000              | memory_map24<br>memory map 24 [11:2], bit[1:0] is stuck to 0. |
| 1:0        | RO          | 0x0                | reserved                                                      |

**CRYPTO PKA MEM MAP25**

Address: Operational Base + offset (0x0864)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                            |
|------------|-------------|--------------------|---------------------------------------------------------------|
| 31:12      | RO          | 0x0                | reserved                                                      |
| 11:2       | RW          | 0x000              | memory_map25<br>memory map 25 [11:2], bit[1:0] is stuck to 0. |
| 1:0        | RO          | 0x0                | reserved                                                      |

**CRYPTO PKA MEM MAP26**

Address: Operational Base + offset (0x0868)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                            |
|------------|-------------|--------------------|---------------------------------------------------------------|
| 31:12      | RO          | 0x0                | reserved                                                      |
| 11:2       | RW          | 0x000              | memory_map26<br>memory map 26 [11:2], bit[1:0] is stuck to 0. |
| 1:0        | RO          | 0x0                | reserved                                                      |

**CRYPTO PKA MEM MAP27**

Address: Operational Base + offset (0x086c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                            |
|------------|-------------|--------------------|---------------------------------------------------------------|
| 31:12      | RO          | 0x0                | reserved                                                      |
| 11:2       | RW          | 0x000              | memory_map27<br>memory map 27 [11:2], bit[1:0] is stuck to 0. |
| 1:0        | RO          | 0x0                | reserved                                                      |

**CRYPTO PKA MEM MAP28**

Address: Operational Base + offset (0x0870)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                            |
|------------|-------------|--------------------|---------------------------------------------------------------|
| 31:12      | RO          | 0x0                | reserved                                                      |
| 11:2       | RW          | 0x000              | memory_map28<br>memory map 28 [11:2], bit[1:0] is stuck to 0. |
| 1:0        | RO          | 0x0                | reserved                                                      |

**CRYPTO PKA MEM MAP29**

Address: Operational Base + offset (0x0874)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                            |
|------------|-------------|--------------------|---------------------------------------------------------------|
| 31:12      | RO          | 0x0                | reserved                                                      |
| 11:2       | RW          | 0x000              | memory_map29<br>memory map 29 [11:2], bit[1:0] is stuck to 0. |
| 1:0        | RO          | 0x0                | reserved                                                      |

**CRYPTO PKA MEM MAP30**

Address: Operational Base + offset (0x0878)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                            |
|------------|-------------|--------------------|---------------------------------------------------------------|
| 31:12      | RO          | 0x0                | reserved                                                      |
| 11:2       | RW          | 0x000              | memory_map30<br>memory map 30 [11:2], bit[1:0] is stuck to 0. |
| 1:0        | RO          | 0x0                | reserved                                                      |

**CRYPTO PKA MEM MAP31**

Address: Operational Base + offset (0x087c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                            |
|------------|-------------|--------------------|---------------------------------------------------------------|
| 31:12      | RO          | 0x0                | reserved                                                      |
| 11:2       | RW          | 0x000              | memory_map31<br>memory map 30 [11:2], bit[1:0] is stuck to 0. |
| 1:0        | RO          | 0x0                | reserved                                                      |

**CRYPTO PKA OPCODE**

Address: Operational Base + offset (0x0880)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:27      | WO          | 0x00               | opcode<br>Defines the PKA operation<br>0x04 Add,Inc<br>0x05 Sub,Dec,Neg<br>0x06 ModAdd,ModInc<br>0x07 ModSub,ModDec,ModNeg<br>0x08 AND,TST0,CLR0<br>0x09 OR,COPY,SET0<br>0xa XOR,FLIP0,INVERT,COMPARE<br>0xc SHR0<br>0xd SHR1<br>0xe SHL0<br>0xf SHL1<br>0x10 MulLow<br>0x11 ModMul<br>0x12 ModMulN<br>0x13 ModExp<br>0x14 Division<br>0x15 Div<br>0x16 ModDiv<br>0x00 Terminate |
| 26:24      | WO          | 0x0                | len<br>The virtual length address 0-7.<br>Virtual address 0 point to PKA_L0.<br>Virtual address 1 point to PKA_L1.<br>...<br>Virtual address 7 point to PKA_L7.                                                                                                                                                                                                                  |
| 23:18      | WO          | 0x00               | reg_a<br>Operand A virtual address 0-15.<br>Virtual address 0 point to PKA_MEM_MAP0.<br>Virtual address 1 point to PKA_MEM_MAP1.<br>...<br>Virtual address 15 point to PKA_MEM_MAP15.                                                                                                                                                                                            |
| 17:12      | WO          | 0x00               | reg_b<br>Operand B virtual address 0-15.<br>Virtual address 0 point to PKA_MEM_MAP0.<br>Virtual address 1 point to PKA_MEM_MAP1.<br>...<br>Virtual address 15 point to PKA_MEM_MAP15.                                                                                                                                                                                            |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11:6       | WO          | 0x00               | reg_r<br>Result register virtual address 0-15.<br>Virtual address 0 point to PKA_MEM_MAP0.<br>Virtual address 1 point to PKA_MEM_MAP1.<br>...<br>Virtual address 15 point to PKA_MEM_MAP15. |
| 5:0        | WO          | 0x00               | tag<br>Tag.                                                                                                                                                                                 |

**CRYPTO\_N\_NP\_TO\_T1\_ADDR**

Address: Operational Base + offset (0x0884)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                     |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20      | RO          | 0x0                | reserved                                                                                                                                                                                               |
| 19:15      | RW          | 0x1f               | reg_t1<br>Virtual address of temporary register number 1.<br>Virtual address 0 point to PKA_MEM_MAP0.<br>Virtual address 1 point to PKA_MEM_MAP1.<br>...<br>Virtual address 15 point to PKA_MEM_MAP15. |
| 14:10      | RW          | 0x1e               | reg_t0<br>Virtual address of temporary register number 0.<br>Virtual address 0 point to PKA_MEM_MAP0.<br>Virtual address 1 point to PKA_MEM_MAP1.<br>...<br>Virtual address 15 point to PKA_MEM_MAP15. |
| 9:5        | RW          | 0x01               | reg_np<br>Virtual address of register np.<br>Virtual address 0 point to PKA_MEM_MAP0.<br>Virtual address 1 point to PKA_MEM_MAP1.<br>...<br>Virtual address 15 point to PKA_MEM_MAP15.                 |
| 4:0        | RW          | 0x00               | reg_n<br>Virtual address of register n.<br>Virtual address 0 point to PKA_MEM_MAP0.<br>Virtual address 1 point to PKA_MEM_MAP1.<br>...<br>Virtual address 15 point to PKA_MEM_MAP15.                   |

**CRYPTO\_PKA\_STATUS**

Address: Operational Base + offset (0x0888)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                |
|------------|-------------|--------------------|-----------------------------------|
| 31:20      | RO          | 0x0                | reserved                          |
| 19:14      | RO          | 0x00               | tag<br>Tag of the Last Operation. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------|
| 13:9       | RO          | 0x00               | opcode<br>the last OPCODE.                                                          |
| 8          | RO          | 0x0                | pka_cpu_busy<br>PKA is busy memory control is by PKA.                               |
| 7          | RO          | 0x0                | modinv_of_zero<br>modular inverse of zero flag.                                     |
| 6          | RO          | 0x0                | alu_sign_out<br>sign of the last operation(MSB).                                    |
| 5          | RO          | 0x0                | alu_carry<br>Carry of the last ALU operation.                                       |
| 4          | RO          | 0x0                | div_by_zero<br>Division by 0.                                                       |
| 3          | RO          | 0x0                | alu_mod_ovflw<br>Modular overflow flag.                                             |
| 2          | RO          | 0x0                | alu_out_zero<br>ALU out is 0.                                                       |
| 1          | RO          | 0x0                | pka_busy<br>PKA is busy.                                                            |
| 0          | RO          | 0x1                | pipe_is_busy<br>PKA ready signal<br>0 : pipe full<br>1 : PKA ready for new command. |

**CRYPTO\_PKA\_SW\_RESET**

Address: Operational Base + offset (0x088c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x0                | reserved                                                                                                                    |
| 0          | WO          | 0x0                | pka_sw_reset<br>PKA software reset the reset mechanism will take about four PKA clocks until the reset line is de-asserted. |

**CRYPTO\_PKA\_L0**

Address: Operational Base + offset (0x0890)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:13      | RO          | 0x0                | reserved                             |
| 12:0       | RW          | 0x0000             | pka_l0<br>PKA length 0, in bit unit. |

**CRYPTO\_PKA\_L1**

Address: Operational Base + offset (0x0894)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:13      | RO          | 0x0                | reserved                             |
| 12:0       | RW          | 0x0000             | pka_l1<br>PKA length 1, in bit unit. |

**CRYPTO\_PKA\_L2**

Address: Operational Base + offset (0x0898)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:13      | RO          | 0x0                | reserved                             |
| 12:0       | RW          | 0x0000             | pka_l2<br>PKA length 2, in bit unit. |

**CRYPTO\_PKA\_L3**

Address: Operational Base + offset (0x089c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:13      | RO          | 0x0                | reserved                             |
| 12:0       | RW          | 0x0000             | pka_l3<br>PKA length 3, in bit unit. |

**CRYPTO\_PKA\_L4**

Address: Operational Base + offset (0x08a0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:13      | RO          | 0x0                | reserved                             |
| 12:0       | RW          | 0x0000             | pka_l4<br>PKA length 4, in bit unit. |

**CRYPTO\_PKA\_L5**

Address: Operational Base + offset (0x08a4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:13      | RO          | 0x0                | reserved                             |
| 12:0       | RW          | 0x0000             | pka_l5<br>PKA length 5, in bit unit. |

**CRYPTO\_PKA\_L6**

Address: Operational Base + offset (0x08a8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:13      | RO          | 0x0                | reserved                             |
| 12:0       | RW          | 0x0000             | pka_l6<br>PKA length 6, in bit unit. |

**CRYPTO\_PKA\_L7**

Address: Operational Base + offset (0x08ac)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:13      | RO          | 0x0                | reserved                             |
| 12:0       | RW          | 0x0000             | pka_l7<br>PKA length 7, in bit unit. |

**CRYPTO PKA PIPE RDY**

Address: Operational Base + offset (0x08b0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                               |
|------------|-------------|--------------------|--------------------------------------------------|
| 31:1       | RO          | 0x0                | reserved                                         |
| 0          | RO          | 0x1                | pka_pipe_rdy<br>PKA pipe is ready for new opcode |

**CRYPTO PKA DONE**

Address: Operational Base + offset (0x08b4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                        |
|------------|-------------|--------------------|-----------------------------------------------------------|
| 31:1       | RO          | 0x0                | reserved                                                  |
| 0          | RO          | 0x1                | pka_done<br>PKA operation is completed and pipe is empty. |

**CRYPTO PKA MON SELECT**

Address: Operational Base + offset (0x08b8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------|
| 31:4       | RO          | 0x0                | reserved                                                                    |
| 3:0        | RW          | 0x0                | pka_mon_select<br>PKA monitor select which PKA fsm monitor is being output. |

**CRYPTO PKA DEBUG REG EN**

Address: Operational Base + offset (0x08bc)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                           |
|------------|-------------|--------------------|--------------------------------------------------------------|
| 31:1       | RO          | 0x0                | reserved                                                     |
| 0          | RW          | 0x0                | pka_debug_reg_en<br>Enable all the debug mechanism when set. |

**CRYPTO DEBUG CNT ADDR**

Address: Operational Base + offset (0x08c0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------|
| 31:20      | RO          | 0x0                | reserved                                                                                                                        |
| 19:0       | R/W<br>SC   | 0x00000            | debug_cnt_addr<br>The clock counter initial values. clock is disabled when counter expires. Triggered when pka_debug_en is set. |

**CRYPTO DEBUG EXT ADDR**

Address: Operational Base + offset (0x08c4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                            |
|------------|-------------|--------------------|-----------------------------------------------|
| 31:1       | RO          | 0x0                | reserved                                      |
| 0          | WO          | 0x0                | debug_ext_addr<br>Disable the debug Mechanism |

**CRYPTO PKA DEBUG HALT**

Address: Operational Base + offset (0x08c8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                     |
|------------|-------------|--------------------|--------------------------------------------------------|
| 31:1       | RO          | 0x0                | reserved                                               |
| 0          | RO          | 0x0                | pka_debug_halt<br>In debug mode: PKA is in halt state. |

**CRYPTO\_PKA\_MON\_READ**

Address: Operational Base + offset (0x08d0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                           |
|------------|-------------|--------------------|--------------------------------------------------------------|
| 31:0       | RO          | 0x0000feef         | pka_mon_read<br>This is the PKA monitor bus register output. |

**CRYPTO\_PKA\_INT\_ENA**

Address: Operational Base + offset (0x08d4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------|
| 31:1       | RO          | 0x0                | reserved                                                            |
| 0          | RW          | 0x0                | pka_int_ena<br>1: enable pka interrupt.<br>0: disable pka interrupt |

**CRYPTO\_PKA\_INT\_ST**

Address: Operational Base + offset (0x08d8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                               |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x0                | reserved                                                                                                                                         |
| 0          | W1C         | 0x0                | pka_int_st<br>Indicate that PKA operation completes . After the bit is read, the application should write 1 to clear this bit for next time use. |

**CRYPTO\_SRAM\_ADDR**

Address: Operational Base + offset (0x1000)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sram_addr<br>Sram address starts from 0x1000 to 0x1fff. When RAM_CTL.ram_pka_rdy == 0, application could access sram. Otherwise, application can't . |

## 9.4 Application Note

### 9.4.1 Clock & Reset

There are 4 clock domains in Crypto. The clock and reset signals are described in the following table .

Table 9-1 Crypto Clock &amp; Reset Description

| <b>Signal</b> | <b>Attr</b> | <b>Description</b> |
|---------------|-------------|--------------------|
| hclk          | clock       | AHB clock          |
| aclk          | clock       | AXI master clock   |

| Signal      | Attr  | Description                                                            |
|-------------|-------|------------------------------------------------------------------------|
| clk_core    | clock | Cipher work clock                                                      |
| clk_pka     | clock | PKA work clock                                                         |
| hresetn     | reset | Asynchronously assert, synchronously de-assert to hclk, low active     |
| aresetn     | reset | Asynchronously assert, synchronously de-assert to aclk, low active     |
| resetn_core | reset | Asynchronously assert, synchronously de-assert to clk_core, low active |
| resetn_pka  | reset | Asynchronously assert, synchronously de-assert to clk_pka, low active  |

Each function need different clocks. The applications could gate the un-used clock to save power. Please see the following table for detail information.

Table 9-2 Crypto Clock &amp; Reset Description

| Operation | HCLK | ACLK | CLK_CORE | CLK_PKA |
|-----------|------|------|----------|---------|
| AES       | ON   | ON   | ON       | OFF     |
| DES/TDES  | ON   | ON   | ON       | OFF     |
| HASH/HMAC | ON   | ON   | ON       | OFF     |
| PKA       | ON   | OFF  | OFF      | ON      |
| TRNG      | ON   | OFF  | OFF      | OFF     |

Even when CLK\_CORE is on, Crypto is doing some cipher job. And Crypto could still be able to automatically gate most parts of un-used blocks to save more power, if CRYPTO\_CLK\_CTL.auto\_clkgate\_en is set to '1'. The default value for this bit is also '1'. Application could do a soft reset to a certain clock domain. Please refer to "Chapter CRU" for more details.

#### 9.4.2 Performance

Cipher performance is shown in the following table.

Table 9-3 Crypto Performance Description

| Algorithm                           | block size (Byte) | clk_core frequency (Mhz) | cycle | serial max throughput (MBps) | parallel max throughput (MBps) |
|-------------------------------------|-------------------|--------------------------|-------|------------------------------|--------------------------------|
| DES                                 | 8                 | 200                      | 18    | 88                           | 352                            |
| TDES                                | 8                 | 200                      | 55    | 29                           | 116                            |
| AES-128                             | 16                | 200                      | 12    | 266                          | 1066                           |
| AES-192                             | 16                | 200                      | 14    | 228                          | 914                            |
| AES-256                             | 16                | 200                      | 16    | 200                          | 800                            |
| SHA-1                               | 64                | 200                      | 81    | 158                          | NA                             |
| MD5                                 | 64                | 200                      | 65    | 196                          | NA                             |
| SHA-256/224                         | 64                | 200                      | 65    | 196                          | NA                             |
| SHA-512/384/<br>512_224/<br>512_256 | 128               | 200                      | 81    | 316                          | NA                             |

There are 2 column throughput rates in the table, 1 is serial mode, the other is parallel mode. In parallel mode, there are 4 engines working at the same time . So the speed is 4 times than serial mode. Parallel mode includes ECB/CTR/XTS both encryption and decryption mode, CFB/CBC/CTS only decryption mode. Other modes are serial. HASH doesn't have parallel mode.

For PKA, the cycles for each calculation are not certain. It depends on the parameters. Take RSA-2048 for example, it takes about 28M cycles to finish a calculation. PKA can run 300 Mhz. It means it can run over 10 times per second.

#### 9.4.3 DMA

DMA supports Link List Item (LLI) DMA transaction.

- Each item contains 8 bytes, and start address should be 8 bytes align ;

- We suggest that DATA start address is 8 bytes align ;
- Total DATA length is byte align.
- Support segmenting HASH/HMAC DATA into multi sections. We suggest that each section DATA length is a multiple of 64 bytes, except this section is the last section.



Fig. 9-2 LLI DMA Usage

As shown in the Figure above, Register CRYPTO\_DMA\_LLI\_ADDR points to 1'st LLI item in external memory. Each LLI item contains DATA address, length, control information and next LLI item pointer, except the last LLI item. The last item doesn't have the next LLI Item pointer. After the last LLI item is finished , DMA will go to idle state.

LLI item definition is shown in the following table.

Table 9-4 LLI Item Description

| <b>offset</b> | <b>Def</b>         | <b>Description</b>                                                        |
|---------------|--------------------|---------------------------------------------------------------------------|
| 0x00          | SRC_ADDRESS[31:0]  | source data start address                                                 |
| 0x04          | SRC_LENGTH[31:0]   | source data length, in byte unit                                          |
| 0x08          | DST_ADDRESS[31:0]  | destination data start address                                            |
| 0x0c          | DST_LENGTH[31:0]   | destination data length, in byte unit                                     |
| 0x10          | USER_DEFINE[31:0]  | used in cipher block                                                      |
| 0x14          | reserve            | reserve                                                                   |
| 0x18          | DMA_CTRL[31:0]     | used in DMA block                                                         |
| 0x1c          | next address[31:0] | next LLI item address. When DMA_CTRL.LAST = "1", NEXT_ADDRESS is invalid. |

DMA\_CTRL: the definition is shown in the following table.

Table 9-5 LLI Item dma\_ctl Description

| <b>Bit</b> | <b>Def</b>              | <b>Definition</b>                                                                                       |
|------------|-------------------------|---------------------------------------------------------------------------------------------------------|
| [31:24]    | ITEM_ID[7:0]            | used to identify LLI items.                                                                             |
| [23:16]    | reserve                 |                                                                                                         |
| [15:11]    | reserve                 |                                                                                                         |
| 10         | source_item_done enable | When source data fetch is completed, CRYPTO_DMA_INT_ST.source_item_done will assert if this bit is set. |
| 9          | reserved                | reserved                                                                                                |
| 8          | list_done enable        | When all LLI items transfer is completed, CRYPTO_DMA_INT_ST.list_done will assert if this bit is set.   |
| [7:2]      | reserved                | reserved                                                                                                |

| Bit | Def   | Definition                                                                                                         |
|-----|-------|--------------------------------------------------------------------------------------------------------------------|
| 1   | PAUSE | indicate DMA will hold on after executes current item. DMA won't go on unless CRYPTO_DMA_CTL.restart is configured |
| 0   | LAST  | indicate current item is the last one. After executes current item, DMA will return to IDLE state.                 |

Table 9-6 LLI Item user\_define Description

| Bit  | Signal       | Description                                                                  |
|------|--------------|------------------------------------------------------------------------------|
| 31:9 | Reserved     | Reserved                                                                     |
| 8    | otpkey_sel   | otpkey select. 1: select otpkey; 0: select register key                      |
| 7    | Privacy_sel  | pkey select. 1: select pkey ; 0: select key ;                                |
| 6:4  | Chnl_num     | channel number, from 0 to 7 .                                                |
| 3    | String_attr  | indicate current item's attribution. 0: ADA ; 1: PC(plaintext or ciphertext) |
| 2    | String_last  | indicate current item is the string last item                                |
| 1    | String_start | indicate current item is the string first item                               |
| 0    | Cipher_start | indicate current item is the cipher first item                               |

#### 9.4.4 Multi-Channel Map

There are 8-channel configurations for AES or DES/TDES operation. For different key-size, the map is different. Please find the register map in the following table.

Table 9-7 LLI Item user\_define Description

| Cipher sel       | otpkey sel | privacy sel | chnl num | key                         | iv(tag/...)             |
|------------------|------------|-------------|----------|-----------------------------|-------------------------|
| AES-128/<br>DES  | 0          | 0           | 0        | CH0_KEY0-3/<br>CH0_KEY0-1   | CH0_IV0-3/<br>CH0_IV0-1 |
| AES-128/<br>DES  | 0          | 0           | n        | CHn_KEY0-3/<br>CHn_KEY0-1   | CHn_IV0-3/<br>CHn_IV0-1 |
| AES-128/<br>DES  | 0          | 0           | 7        | CH7_KEY0-3/<br>CH7_KEY0-1   | CH7_IV0-3/<br>CH7_IV0-1 |
| AES-128/<br>DES  | 0          | 1           | 0        | CH0_PKEY0-3/<br>CH0_PKEY0-1 | CH0_IV0-3/<br>CH0_IV0-1 |
| AES-128/<br>DES  | 0          | 1           | n        | CHn_PKEY0-3/<br>CHn_PKEY0-1 | CHn_IV0-3/<br>CHn_IV0-1 |
| AES-128/<br>DES  | 0          | 1           | 7        | CH7_PKEY0-3/<br>CH7_PKEY0-1 | CH7_IV0-3/<br>CH7_IV0-1 |
| AES-128/<br>DES  | 1          | NA          | 0        | OTP_KEY[255:128]            | CH0_IV0-3/<br>CH0_IV0-1 |
| AES-128/<br>DES  | 1          | NA          | n        | OTP_KEY[127:0]              | CHn_IV0-3/<br>CHn_IV0-1 |
| AES-128/<br>DES  | 1          | NA          | 7        | OTP_KEY[127:0]              | CH7_IV0-3/<br>CH7_IV0-1 |
| AES-192/<br>TDES | 0          | 0           | 0        | CH0_KEY0-3,<br>CH1_KEY0-1   | CH0_IV0-3/<br>CH0_IV0-1 |
| AES-192/<br>TDES | 0          | 0           | 1        | CH2_KEY0-3,<br>CH3_KEY0-1   | CH1_IV0-3/<br>CH1_IV0-1 |

| <b>Cipher sel</b> | <b>otpkey sel</b> | <b>privacy sel</b> | <b>chnl num</b> | <b>key</b>                  | <b>iv(tag/...)</b>      |
|-------------------|-------------------|--------------------|-----------------|-----------------------------|-------------------------|
| AES-192/TDES      | 0                 | 0                  | 2               | CH4_KEY0-3,<br>CH5_KEY0-1   | CH2_IV0-3/<br>CH2_IV0-1 |
| AES-192/TDES      | 0                 | 0                  | 3               | CH6_KEY0-3,<br>CH7_KEY0-1   | CH3_IV0-3/<br>CH3_IV0-1 |
| AES-192/TDES      | 0                 | 1                  | 0               | CH0_PKEY0-3,<br>CH1_PKEY0-1 | CH0_IV0-3/<br>CH0_IV0-1 |
| AES-192/TDES      | 0                 | 1                  | 1               | CH2_PKEY0-3,<br>CH3_PKEY0-1 | CH1_IV0-3/<br>CH1_IV0-1 |
| AES-192/TDES      | 0                 | 1                  | 2               | CH4_PKEY0-3,<br>CH5_PKEY0-1 | CH2_IV0-3/<br>CH2_IV0-1 |
| AES-192/TDES      | 0                 | 1                  | 3               | CH6_PKEY0-3,<br>CH7_PKEY0-1 | CH3_IV0-3/<br>CH3_IV0-1 |
| AES-192/TDES      | 0                 | NA                 | 4-7             | not supported               | not supported           |
| AES-192/TDES      | 1                 | NA                 | 0               | OTP[255:64]                 | CH0_IV0-3/<br>CH0_IV0-1 |
| AES-192/TDES      | 1                 | NA                 | 1-7             | not supported               | not supported           |
| AES-256           | 0                 | 0                  | 0               | CH0_KEY0-3,<br>CH1_KEY0-3   | CH0_IV0-3/<br>CH0_IV0-1 |
| AES-256           | 0                 | 0                  | 1               | CH2_KEY0-3,<br>CH3_KEY0-3   | CH1_IV0-3/<br>CH1_IV0-1 |
| AES-256           | 0                 | 0                  | 2               | CH4_KEY0-3,<br>CH5_KEY0-3   | CH2_IV0-3/<br>CH2_IV0-1 |
| AES-256           | 0                 | 0                  | 3               | CH6_KEY0-3,<br>CH7_KEY0-3   | CH3_IV0-3/<br>CH3_IV0-1 |
| AES-256           | 0                 | 1                  | 0               | CH0_PKEY0-3,<br>CH1_PKEY0-3 | CH0_IV0-3/<br>CH0_IV0-1 |
| AES-256           | 0                 | 1                  | 1               | CH2_PKEY0-3,<br>CH3_PKEY0-3 | CH1_IV0-3/<br>CH1_IV0-1 |
| AES-256           | 0                 | 1                  | 2               | CH4_PKEY0-3,<br>CH5_PKEY0-3 | CH2_IV0-3/<br>CH2_IV0-1 |
| AES-256           | 0                 | 1                  | 3               | CH6_PKEY0-3,<br>CH7_PKEY0-3 | CH3_IV0-3/<br>CH3_IV0-1 |
| AES-256           | 0                 | NA                 | 4-7             | not supported               | not supported           |
| AES-256           | 1                 | NA                 | 0               | OTP[255:0]                  | CH0_IV0-3/<br>CH0_IV0-1 |
| AES-256           | 1                 | NA                 | 1-7             | not supported               | not supported           |

In AES-XTS mode, there are 2 keys, and only AES-128 and AES-256 mode are. Please refer to the following table for detail information.

Table 9-8 LLI Item user\_define Description

| <b>Cipher sel</b> | <b>otpkey sel</b> | <b>privacy sel</b> | <b>chnl num</b> | <b>key1</b> | <b>key2</b> | <b>tweak</b> |
|-------------------|-------------------|--------------------|-----------------|-------------|-------------|--------------|
| AES-128           | 0                 | 0                  | 0               | CH0_KEY0-3  | CH4_KEY0-3  | CH0_IV0-3    |

| Cipher sel | otpkey sel | privacy sel | chnl num | key1                        | key2                    | tweak         |
|------------|------------|-------------|----------|-----------------------------|-------------------------|---------------|
| AES-128    | 0          | 0           | 1        | CH1_KEY0-3                  | CH5_KEY0-3              | CH1_IV0-3     |
| AES-128    | 0          | 0           | 2        | CH2_KEY0-3                  | CH6_KEY0-3              | CH2_IV0-3     |
| AES-128    | 0          | 0           | 3        | CH3_KEY0-3                  | CH7_KEY0-3              | CH3_IV0-3     |
| AES-128    | 0          | 1           | 0        | CH0_PKEY0-3                 | CH4_PKEY0-3             | CH0_IV0-3     |
| AES-128    | 0          | 1           | 1        | CH1_PKEY0-3                 | CH5_PKEY0-3             | CH1_IV0-3     |
| AES-128    | 0          | 1           | 2        | CH2_PKEY0-3                 | CH6_PKEY0-3             | CH2_IV0-3     |
| AES-128    | 0          | 1           | 3        | CH3_PKEY0-3                 | CH7_PKEY0-3             | CH3_IV0-3     |
| AES-128    | 0          | NA          | 4-7      | not supported               | not supported           | not supported |
| AES-128    | 1          | NA          | NA       | not supported               | not supported           | not supported |
| AES-256    | 0          | 0           | 0        | CH0_KEY0-3,<br>CH1_KEY0-3   | CH4_KEY0-<br>CH5_KEY3   | CH0_IV0-3     |
| AES-256    | 0          | 0           | 1        | CH2_KEY0-3,<br>CH3_KEY0-3   | CH6_KEY0-<br>CH7_KEY3   | CH1_IV0-3     |
| AES-256    | 0          | 1           | 0        | CH0_PKEY0-3,<br>CH1_PKEY0-3 | CH4_PKEY0-<br>CH5_PKEY3 | CH0_IV0-3     |
| AES-256    | 0          | 1           | 1        | CH2_PKEY0-3,<br>CH3_PKEY0-3 | CH6_PKEY0-<br>CH7_PKEY3 | CH1_IV0-3     |
| AES-256    | 0          | NA          | 2-7      | not supported               | not supported           | not supported |
| AES-256    | 1          | NA          | NA       | not supported               | not supported           | not supported |

Note: The difference between CHn\_KEY and CHn\_PKEY is that: CHn\_KEY could be read/write, CHn\_PKEY could be write , but can't be read . The read value for CHn\_PKEY is all '0'.

#### 9.4.5 HASH Data Path

HASH and AES could run in parallel way. There are 2 paths lead to AES-HASH function. One is AES-HASH-RX mode, the other is AES-HASH-TX mode.



Fig. 9-3 AES-HASH-RX mode



Fig. 9-4 AES-HASH-TX mode

As shown in the figures above, we could facilitate operations in some cases. For example, secure boot, we need both AES and HASH operations for the same blocks of data. The data HASH gets from RX\_FIFO or TX\_FIFO is byteswaped if the byteswap function is configured.

#### 9.4.6 Program Steps

The application could succeed various crypto operations if they program properly.

- Program the LLI address to DMA\_LLI\_ADDR;
- Program KEY , IV, or other parameter if needed ;
- Program BC\_CTL or HASH\_CTL for control information;
- Prepare LLI Item;
- Enable interrupt, or do nothing.

All these operations could be in any order.

- Program DMA\_CTL.start to start the operation;

This step should be the last configuration step. After this register is configured, other registers should not be changed.

- Wait interrupt asserted, or just poll the DMA\_INT\_ST bits .
- Program DMA\_INT\_ST to clear interrupt status, and get the result.

The application could also use LLI.pause when the next LLI item is not ready. After the new item is prepared, the application could program DMA\_CTL.restart to continue previous operation.

## Chapter 10 USB OTG2.0

### 10.1 Overview

USB OTG 2.0 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.

USB OTG 2.0 is optimized for portable electronic devices, point-to-point applications (no hub, direct connection to device) and multi-point applications to devices.

#### 10.1.1 Features

- Compliant with the OTG Supplement to the USB2.0 Specification
- Operates in High-Speed, Full-Speed and Low-Speed mode (host mode only)
- 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, dynamic FIFO memory allocation for endpoints for flexible, efficient use of RAM
- Support dynamic FIFO sizing

### 10.2 Block Diagram



Fig. 10-1 USB OTG 2.0 Architecture

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

### 10.3 USB OTG 2.0 Controller

The USB OTG 2.0 Controller can active as USB2.0 host controller or USB2.0 device controller basing on ID status of Micron-AB receptacle.

As USB2.0 host controller, it uses one transmit FIFO for all non-periodic out transactions and one transmit FIFO for all periodic out transactions as transmit buffers to hold the data to be transmitted over USB, and use one receive FIFO for all periodic and non-periodic transactions to hold the received data from the USB until it is transferred to the system memory by DMA.

As USB2.0 device controller, it also use a single receive FIFO to receive the data for all the out endpoints from USB, and individual transmit FIFOs for each IN endpoint.

### 10.4 USB OTG 2.0 PHY

The USB OTG 2.0 PHY handles the low level USB protocol and signaling from controller and differential pairs. It includes functions such as data serialization and de-serialization, bit stuffing and clock recovery and synchronization. Its feature contains:

- provide dual UTMI ports
- OTG0 Support UART Bypass Function
- Fully compliant with USB specifications Rev 2.0
- Supports 480Mbps (HS), 12Mbps (FS) & 1.5Mbps(LS) serial data transmission

- Supports low latency hub mode with 40 bit time around trip delay
- 8 bit or 16 bit UTMI interface compliant with UTMI+ specification level 3 Rev 1.
- Loop back BIST mode supported
- Built-in I/O and ESD structure
- On-die self-calibrated HS/FS/LS termination
- 24MHz crystal oscillator with integrated phase-locked loop (PLL) oscillator
- Dual 3.3V / 1.2V supply

## 10.5 UART BYPASS FUNCITON

UART bypass mode is used for software team debugging by transmitting UART signals over USB differential pairs. When in UART bypass mode, UART2 can transmit UART protocol signals over USB differential pairs and USB is not functional; Otherwise, UART2 use normal UART interface and USB is functional.

## 10.6 Register Description

### 10.6.1 Register Summary

| Name             | Offset | Size | Reset Value | Description                                      |
|------------------|--------|------|-------------|--------------------------------------------------|
| USBOTG_GOTGCTL   | 0x0000 | W    | 0x00000000  | Control and Status Register                      |
| USBOTG_GOTGINT   | 0x0004 | W    | 0x00000000  | Interrupt Register                               |
| USBOTG_GAHBCFG   | 0x0008 | W    | 0x00000000  | AHB Configuration Register                       |
| USBOTG_GUSBCFG   | 0x000c | W    | 0x00001400  | USB Configuration Register                       |
| USBOTG_GRSTCTL   | 0x0010 | W    | 0x80000000  | Reset Register                                   |
| USBOTG_GINTSTS   | 0x0014 | W    | 0x00000000  | Interrupt Register                               |
| USBOTG_GINTMSK   | 0x0018 | W    | 0x00000000  | Interrupt Mask Register                          |
| USBOTG_GRXSTSR   | 0x001c | W    | 0x00000000  | Receive Status Debug Read Register               |
| USBOTG_GRXSTSP   | 0x0020 | W    | 0x00000000  | Receive Status Read and Pop Register             |
| USBOTG_GRXFSIZ   | 0x0024 | W    | 0x00000000  | Receive FIFO Size Register                       |
| USBOTG_GNPTXFSIZ | 0x0028 | W    | 0x00000000  | Non-Periodic Transmit FIFO Size Register         |
| USBOTG_GNPTXSTS  | 0x002c | W    | 0x00000000  | Non-Periodic Transmit FIFO/Queue Status Register |
| USBOTG_GI2CCTL   | 0x0030 | W    | 0x11000000  | I2C Address Register                             |
| USBOTG_GPVNDCTL  | 0x0034 | W    | 0x00000000  | PHY Vendor Control Register                      |
| USBOTG_GGPIO     | 0x0038 | W    | 0x00000000  | General Purpost Input/Output Register            |
| USBOTG_GUID      | 0x003c | W    | 0x00000000  | User ID Register                                 |
| USBOTG_GSNPSID   | 0x0040 | W    | 0x00004f54  | Core ID Register                                 |
| USBOTG_GHWCFG1   | 0x0044 | W    | 0x00000000  | User HW Config1 Register                         |
| USBOTG_GHWCFG2   | 0x0048 | W    | 0x00000000  | User HW Config2 Register                         |
| USBOTG_GHWCFG3   | 0x004c | W    | 0x00000000  | User HW Config3 Register                         |
| USBOTG_GHWCFG4   | 0x0050 | W    | 0x00000000  | User HW Config4 Register                         |
| USBOTG_GLPMCFG   | 0x0054 | W    | 0x00000000  | Core LPM Configuration Register                  |
| USBOTG_GPWRDN    | 0x0058 | W    | 0x00000000  | Global Power Down Register                       |

| <b>Name</b>       | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>                                 |
|-------------------|---------------|-------------|--------------------|----------------------------------------------------|
| USBOTG_GDFIFO CFG | 0x005c        | W           | 0x00000000         | Global DFIFO Software Config Register              |
| USBOTG_GADPCTL    | 0x0060        | W           | 0x00000000         | ADP Timer,Control and Status Register              |
| USBOTG_HPTXFSIZ   | 0x0100        | W           | 0x00000000         | Host Periodic Transmit FIFO Size Register          |
| USBOTG_DIEPTXFn   | 0x0104        | W           | 0x00000000         | Device Periodic Transmit FIFO-n Size Register      |
| USBOTG_HCFG       | 0x0400        | W           | 0x00000000         | Host Configuration Register                        |
| USBOTG_HFIR       | 0x0404        | W           | 0x00000000         | Host Frame Interval Register                       |
| USBOTG_HFNUM      | 0x0408        | W           | 0x0000ffff         | Host Frame Number/Frame Time Remaining Register    |
| USBOTG_HPTXSTS    | 0x0410        | W           | 0x00000000         | Host Periodic Transmit FIFO/Queue Status Register  |
| USBOTG_HAINT      | 0x0414        | W           | 0x00000000         | Host All Channels Interrupt Register               |
| USBOTG_HAINTMSK   | 0x0418        | W           | 0x00000000         | Host All Channels Interrupt Mask Register          |
| USBOTG_HPRT       | 0x0440        | W           | 0x00000000         | Host Port Control and Status Register              |
| USBOTG_HCCHARn    | 0x0500        | W           | 0x00000000         | Host Channel-n Characteristics Register            |
| USBOTG_HCSPLTn    | 0x0504        | W           | 0x00000000         | Host Channel-n Split Control Register              |
| USBOTG_HCINTn     | 0x0508        | W           | 0x00000000         | Host Channel-n Interrupt Register                  |
| USBOTG_HCINTMSKn  | 0x050c        | W           | 0x00000000         | Host Channel-n Interrupt Mask Register             |
| USBOTG_HCTSIZn    | 0x0510        | W           | 0x00000000         | Host Channel-n Transfer Size Register              |
| USBOTG_HCDMAN     | 0x0514        | W           | 0x00000000         | Host Channel-n DMA Address Register                |
| USBOTG_HCDMABn    | 0x051c        | W           | 0x00000000         | Host Channel-n DMA Buffer Address Register         |
| USBOTG_DCFG       | 0x0800        | W           | 0x08200000         | Device Configuration Register                      |
| USBOTG_DCTL       | 0x0804        | W           | 0x00002000         | Device Control Register                            |
| USBOTG_DSTS       | 0x0808        | W           | 0x00000000         | Device Status Register                             |
| USBOTG_DIEPMSK    | 0x0810        | W           | 0x00000000         | Device IN Endpoint common interrupt mask register  |
| USBOTG_DOEPMSK    | 0x0814        | W           | 0x00000000         | Device OUT Endpoint common interrupt mask register |
| USBOTG_DAINT      | 0x0818        | W           | 0x00000000         | Device All Endpoints interrupt register            |

| Name                         | Offset | Size | Reset Value | Description                                            |
|------------------------------|--------|------|-------------|--------------------------------------------------------|
| USBOTG_DAINTMSK              | 0x081c | W    | 0x000000000 | Device All Endpoint interrupt mask register            |
| USBOTG_DTKNQR1               | 0x0820 | W    | 0x000000000 | Device IN token sequence learning queue read register1 |
| USBOTG_DTKNQR2               | 0x0824 | W    | 0x000000000 | Device IN token sequence learning queue read register2 |
| USBOTG_DVBUSDIS              | 0x0828 | W    | 0x000000b8f | Device VBUS discharge time register                    |
| USBOTG_DVBUSPULSE            | 0x082c | W    | 0x000000000 | Device VBUS Pulsing Timer Register                     |
| USBOTG_DTHRCTL               | 0x0830 | W    | 0x08100020  | Device Threshold Control Register                      |
| USBOTG_DIEPEMPMSK            | 0x0834 | W    | 0x000000000 | Device IN endpoint FIFO empty interrupt mask register  |
| USBOTG_DEACHINT              | 0x0838 | W    | 0x000000000 | Device each endpoint interrupt register                |
| USBOTG_DEACHINTMSK           | 0x083c | W    | 0x000000000 | Device each endpoint interrupt register mask           |
| USBOTG_DIEPEACHMSKn          | 0x0840 | W    | 0x000000000 | Device each IN endpoint -n interrupt Register          |
| USBOTG_DOEPEACHMSKn          | 0x0880 | W    | 0x000000000 | Device each out endpoint-n interrupt register          |
| USBOTG_DIEPCTL0              | 0x0900 | W    | 0x00008000  | Device control IN endpoint 0 control register          |
| USBOTG_DIEPINTn              | 0x0908 | W    | 0x000000000 | Device Endpoint-n Interrupt Register                   |
| USBOTG_DIEPTSIZn             | 0x0910 | W    | 0x000000000 | Device endpoint n transfer size register               |
| USBOTG_DIEPDMAAn             | 0x0914 | W    | 0x000000000 | Device endpoint-n DMA address register                 |
| USBOTG_DTXFSTS <sub>n</sub>  | 0x0918 | W    | 0x000000000 | Device IN endpoint transmit FIFO status register       |
| USBOTG_DIEPDMAB <sub>n</sub> | 0x091c | W    | 0x000000000 | Device endpoint-n DMA buffer address register          |
| USBOTG_DIEPCTL <sub>n</sub>  | 0x0920 | W    | 0x000000000 | Device endpoint-n control register                     |
| USBOTG_DOEPCTL0              | 0x0b00 | W    | 0x000000000 | Device control OUT endpoint 0 control register         |
| USBOTG_DOEPINTn              | 0x0b08 | W    | 0x000000000 | Device endpoint-n control register                     |
| USBOTG_DOEPTSIZn             | 0x0b10 | W    | 0x000000000 | Device endpoint n transfer size register               |
| USBOTG_DOEPDMAAn             | 0x0b14 | W    | 0x000000000 | Device Endpoint-n DMA Address Register                 |
| USBOTG_DOEPDMAB <sub>n</sub> | 0x0b1c | W    | 0x000000000 | Device endpoint-n DMA buffer address register          |

| Name            | Offset | Size | Reset Value | Description                                    |
|-----------------|--------|------|-------------|------------------------------------------------|
| USBOTG_DOEPCTLn | 0x0b20 | W    | 0x00000000  | Device endpoint-n control register             |
| USBOTG_PCGCR    | 0x0b24 | W    | 0x200b8000  | Power and clock gating control register        |
| USBOTG_EPBUFO   | 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    | 0x00000000  | 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    | 0x00000000  | 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    | 0x00000000  | 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

## 10.6.2 Detail Register Description

### USBOTG\_GOTGCTL

Address: Operational Base + offset (0x0000)

Control and Status Register

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                            |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                               |
| 27    | RW   | 0x0         | ChirpEn<br>Chirp on enable<br>This bit when programmed to 1'b1 results in the core asserting chirp_on before sending an actual Chirp "K" signal on USB. This bit is present only if OTG_BC_SUPPORT = 1. If OTG_BC_SUPPORT != 1, this bit is a reserved bit.                                            |
| 26:22 | RO   | 0x00        | MultValidBc<br>Multi Valued ID pin<br>Battery Charger ACA inputs in the following order:<br>Bit 26 - rid_float.<br>Bit 25 - rid_gnd<br>Bit 24 - rid_a<br>Bit 23 - rid_b<br>Bit 22 - rid_c<br>These bits are present only if OTG_BC_SUPPORT = 1. Otherwise, these bits are reserved and will read 5'h0. |
| 21    | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 20         | RW          | 0x0                | <p>OTGVer<br/>OTG version<br/>Indicates the OTG revision.<br/>0: OTG Version 1.3. In this version the core supports Data line pulsing and VBus pulsing for SRP.<br/>1: OTG Version 2.0. In this version the core supports only Data line pulsing for SRP.</p>                                                                                                                                                              |
| 19         | RO          | 0x0                | <p>BSesVld<br/>B-session valid<br/>Indicates the Device mode transceiver status.<br/>0: B-session is not valid.<br/>1: B-session is valid.<br/>In OTG mode, you can use this bit to determine if the device is connected or disconnected. Note: If you do not enable 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.</p> |
| 18         | RO          | 0x0                | <p>ASesVld<br/>A-session valid<br/>Indicates the Host mode transceiver status.<br/>0: A-session is not valid<br/>1: A-session is valid<br/>Note: If you do not enable 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.</p>                                                                                                |
| 17         | RO          | 0x0                | <p>DbnTime<br/>Long/short debounce time<br/>Indicates the debounce time of a detected connection.<br/>0: Long debounce time, used for physical connections (100 ms + 2.5 us)<br/>1: Short debounce time, used for soft connections (2.5 us)</p>                                                                                                                                                                            |
| 16         | RO          | 0x0                | <p>ConIDSts<br/>Connector ID Status<br/>Indicates the connector ID status on a connect event.<br/>0: The core is in A-Device mode<br/>1: The core is in B-Device mode</p>                                                                                                                                                                                                                                                  |
| 15:12      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 11         | RW          | 0x0                | <p>DevHNPEn<br/>Device HNP Enable<br/>The application sets this bit when it successfully receives a SetFeature. SetHNPEnable command from the connected USB host.<br/>0: HNP is not enabled in the application<br/>1: HNP is enabled in the application</p>                                                                                                                                                                |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10         | RW          | 0x0                | <p>HstSetHNPEn<br/>Host set HNP enable<br/>The application sets this bit when it has successfully enabled HNP (using the SetFeature.SetHNPEnable command) on the connected device.</p> <p>0: Host Set HNP is not enabled<br/>1: Host Set HNP is enabled</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 9          | RW          | 0x0                | <p>HNPRq<br/>HNP request<br/>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.</p> <p>0: No HNP request<br/>1: HNP request</p>                                                                                                                                                                                                                                                                                                                                        |
| 8          | RO          | 0x0                | <p>HstNegScs<br/>Host Negotiation Success<br/>The core sets this bit when host negotiation is successful. The core clears this bit when the HNP Request (HNPRq) bit in this register is set.</p> <p>0: Host negotiation failure<br/>1: Host negotiation success</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 7:2        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 1          | RW          | 0x0                | <p>SesReq<br/>Session Request<br/>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.</p> <p>0: No session request<br/>1: Session request</p> |
| 0          | RO          | 0x0                | <p>SesReqScs<br/>Session Request Success<br/>The core sets this bit when a session request initiation is successful.</p> <p>0: Session request failure<br/>1: Session request success</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

**USBOTG\_GOTGINT**

Address: Operational Base + offset (0x0004)

Interrupt Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:21      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                |
| 20         | W1C         | 0x0                | MultiValueChg<br>Multi-Valued input changed<br>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         | 0x0                | DbnceDone<br>Debounce Done<br>The core sets this bit when the debounce is completed after the device connected. 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         | 0x0                | ADevTOUTChg<br>A-Device Timeout Change<br>The core sets this bit to indicate that the A-device has timed out while waiting for the B-device to connect.                                                                                                                                                                                                 |
| 17         | W1C         | 0x0                | HstNegDet<br>Host Negotiation Detected<br>The core sets this bit when it detects a host negotiation request on the USB                                                                                                                                                                                                                                  |
| 16:10      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                |
| 9          | W1C         | 0x0                | HstNegSucStsChng<br>Host Negotiation Success Status Change<br>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         | 0x0                | SesReqSucStsChng<br>Session Request Success Status Change<br>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         | 0x0                | SesEndDet<br>Session End Detected<br>The core sets this bit when the utmisrp_bvalid signal is deasserted                                                                                                                                                                                                                                                |
| 1:0        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                |

**USBOTG\_GAHBCFG**

Address: Operational Base + offset (0x0008)

AHB Configuration Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:23      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 22         | RW          | 0x0                | <p>NotiAllDmaWrit<br/>Notify All Dma Write Transactions<br/>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.<br/>GAHBCFG.NotiAllDmaWrit = 1.</p> <p>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.</p> <p>HSOTG core asserts int_dma_req signal only for the last transaction of DMA write transfer 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.</p> |
| 21         | RW          | 0x0                | <p>RemMemSupp<br/>Remote Memory Support<br/>This bit is programmed to enable the functionality to wait for the system DMA Done Signal for the DMA Write Transfers.<br/>GAHBCFG.RemMemSupp=1.</p> <p>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. 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.</p> <p>GAHBCFG.RemMemSupp=0.</p> <p>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.</p>                                           |
| 20:9       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8          | RW          | 0x0                | <p>PTxFEmpLvl<br/>Periodic TxFIFO Empty Level<br/>Indicates when the Periodic TxFIFO Empty Interrupt bit in the Core Interrupt register (GINTSTS.PTxFEmp) is triggered. This bit is used only in Slave mode.</p> <p>0: GINTSTS.PTxFEmp interrupt indicates that the Periodic TxFIFO is half empty<br/>1: GINTSTS.PTxFEmp interrupt indicates that the Periodic TxFIFO is completely empty</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 7          | RW          | 0x0                | <p>NPTxFEmpLvl<br/>Non-Periodic TxFIFO Empty Level<br/>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.</p> <p>Host mode and with Shared FIFO with device mode:<br/>1'b0: GINTSTS.NPTxFEmp interrupt indicates that the Non-Periodic TxFIFO is half empty<br/>1'b1: GINTSTS.NPTxFEmp interrupt indicates that the Non-Periodic TxFIFO is completely empty</p> <p>Dedicated FIFO in device mode:<br/>1'b0: DIEPINTn.TxFEmp interrupt indicates that the IN Endpoint TxFIFO is half empty<br/>1'b1: DIEPINTn.TxFEmp interrupt indicates that the IN Endpoint TxFIFO is completely empty</p> |
| 6          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 5          | RW          | 0x0                | <p>DMAEn<br/>DMA Enable<br/>0: Core operates in Slave mode<br/>1: Core operates in a DMA mode<br/>This bit is always 0 when Slave-Only mode has been selected.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4:1        | RW          | 0x0                | <p>HBstLen<br/>Burst Length/Type<br/>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:</p> <ul style="list-style-type: none"> <li>4'b0000: 1 word</li> <li>4'b0001: 4 words</li> <li>4'b0010: 8 words</li> <li>4'b0011: 16 words</li> <li>4'b0100: 32 words</li> <li>4'b0101: 64 words</li> <li>4'b0110: 128 words</li> <li>4'b0111: 256 words</li> <li>Others: Reserved</li> </ul> <p>Internal DMA Mode AHB Master burst type:</p> <ul style="list-style-type: none"> <li>4'b0000: Single</li> <li>4'b0001: INCR</li> <li>4'b0011: INCR4</li> <li>4'b0101: INCR8</li> <li>4'b0111: INCR16</li> <li>Others: Reserved</li> </ul> |
| 0          | RW          | 0x0                | <p>GlbIntrMsk<br/>Global Interrupt Mask<br/>The application uses this bit to mask or unmask the interrupt line assertion by itself. Irrespective of this bit's setting, the interrupt status registers are updated by the core.</p> <p>1'b0: Mask the interrupt assertion to the application.<br/>1'b1: Unmask the interrupt assertion to the application.</p>                                                                                                                                                                                                                                                                                                                                                                                                                      |

**USBOTG\_GUSBCFG**

Address: Operational Base + offset (0x000c)

USB Configuration Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------|
| 31         | RW          | 0x0                | <p>CorruptTxpacket<br/>Corrupt Tx packet<br/>This bit is for debug purposes only. Never set this bit to 1.</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 30         | RW          | 0x0                | <p>ForceDevMode<br/>Force Device Mode<br/>Writing a 1 to this bit forces the core to device mode irrespective of utmiotg_iddig input pin.<br/>1'b0: Normal Mode<br/>1'b1: Force Device Mode<br/>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.</p> |
| 29         | RW          | 0x0                | <p>ForceHstMode<br/>Force Host Mode<br/>Writing a 1 to this bit forces the core to host mode irrespective of utmiotg_iddig input pin.<br/>1'b0: Normal Mode<br/>1'b1: Force Host Mode<br/>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.</p>         |
| 28         | RW          | 0x0                | <p>TxEndDelay<br/>Tx End Delay<br/>Writing a 1 to this bit enables the TxEndDelay timers in the core.<br/>1'b0: Normal mode<br/>1'b1: Introduce Tx end delay timers</p>                                                                                                                                                                                                                                                                                                          |
| 27         | RW          | 0x0                | <p>IC_USB_TrafficCtl<br/>IC_USB TrafficPullRemove Control<br/>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.</p>                                                                                                                                                                                 |
| 26         | RW          | 0x0                | <p>IC_USBCap<br/>IC_USB-Capable<br/>The application uses this bit to control the IC_USB capabilities.<br/>1'b0: IC_USB PHY Interface is not selected.<br/>1'b1: IC_USB PHY Interface is selected.<br/>This bit is writable only if OTG_ENABLE_IC_USB=1 and OTG_FSPHY_INTERFACE!=0.The reset value depends on the configuration parameter OTG_SELECT_IC_USB when OTG_ENABLE_IC_USB = 1. In all other cases, this bit is set to 1'b0 and the bit is read only.</p>                 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 25         | RW          | 0x0                | <p>ULPIIfDis<br/>ULPI Interface Protect Disable<br/>Controls circuitry built into the PHY for protecting the ULPI interface when the link tri-states STP and data. Any pull-ups or pull-downs employed by this feature can be disabled. Please refer to the ULPI Specification for more detail.<br/>1'b0: Enables the interface protect circuit<br/>1'b1: Disables the interface protect circuit</p>                                            |
| 24         | RW          | 0x0                | <p>IndPassThrough<br/>Indicator Pass Through<br/>Controls whether the Complement Output is qualified with the Internal Vbus Valid comparator before being used in the Vbus State in the RX CMD. Please refer to the ULPI Specification for more detail.<br/>1'b0: Complement Output signal is qualified with the Internal VbusValid comparator.<br/>1'b1: Complement Output signal is not qualified with the Internal VbusValid comparator.</p> |
| 23         | RW          | 0x0                | <p>IndComple<br/>Indicator Complement<br/>Controls the PHY to invert the ExternalVbusIndicator input signal,generating the Complement Output. Please refer to the ULPI Specification for more detail<br/>1'b0: PHY does not invert ExternalVbusIndicator signal<br/>1'b1: PHY does invert ExternalVbusIndicator signal</p>                                                                                                                      |
| 22         | RW          | 0x0                | <p>TermSelDLpulse<br/>TermSel DLine Pulsing Selection<br/>This bit selects utmi_termselect to drive data line pulse during SRP.<br/>1'b0: Data line pulsing using utmi_txvalid (default).<br/>1'b1: Data line pulsing using utmi_termsel.</p>                                                                                                                                                                                                   |
| 21         | RW          | 0x0                | <p>ULPIExtVbusIndicator<br/>ULPI External VBUS Indicator<br/>This bit indicates to the ULPI PHY to use an external VBUS over-current indicator.<br/>1'b0: PHY uses internal VBUS valid comparator.<br/>1'b1: PHY uses external VBUS valid comparator.<br/>(Valid only when RTL parameter OTG_HSPHY_INTERFACE = 2 or 3)</p>                                                                                                                      |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 20         | RW          | 0x0                | <p>ULPIExtVbusDrv<br/>ULPI External VBUS Drive</p> <p>This bit selects between internal or external supply to drive 5V on VBUS,in ULPI PHY.</p> <p>1'b0: PHY drives VBUS using internal charge pump (default).</p> <p>1'b1: PHY drives VBUS using external supply.</p> <p>(Valid only when RTL parameter OTG_HSPHY_INTERFACE = 2 or 3)</p>                                                          |
| 19         | RW          | 0x0                | <p>ULPIClkSusM<br/>ULPI Clock SuspendM</p> <p>This bit sets the ClockSuspendM bit in the Interface Control register on the ULPI PHY. This bit applies only in serial or carkit modes.</p> <p>1'b0: PHY powers down internal clock during suspend.</p> <p>1'b1: PHY does not power down internal clock.</p> <p>(Valid only when RTL parameter OTG_HSPHY_INTERFACE = 2 or 3)</p>                      |
| 18         | RW          | 0x0                | <p>ULPIAutoRes<br/>ULPI Auto Resume</p> <p>This bit sets the AutoResume bit in the Interface Control register on the ULPI PHY.</p> <p>1'b0: PHY does not use AutoResume feature.</p> <p>1'b1: PHY uses AutoResume feature.</p> <p>(Valid only when RTL parameter OTG_HSPHY_INTERFACE = 2 or 3)</p>                                                                                                  |
| 17         | RW          | 0x0                | <p>ULPIFsLs<br/>ULPI FS/LS Select</p> <p>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.</p> <p>1'b0: ULPI interface</p> <p>1'b1: ULPI FS/LS serial interface</p> <p>(Valid only when RTL parameters OTG_HSPHY_INTERFACE = 2 or 3 and OTG_FSPHY_INTERFACE = 1, 2, or 3)</p> |
| 16         | RW          | 0x0                | <p>OtgI2CSel<br/>UTMIFS or I2C Interface Select</p> <p>The application uses this bit to select the I2C interface.</p> <p>1'b0: UTMIFS USB 1.1 Full-Speed interface for OTG signals</p> <p>1'b1: I2C interface for OTG signals</p> <p>This bit is writable only if I2C and UTMIFS were specified for Enable I2C Interface (parameter OTG_I2C_INTERFACE = 2). Otherwise, reads return 0.</p>          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15         | RW          | 0x0                | <p>PhyLPwrClkSel<br/>PHY Low-Power Clock Select<br/>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.</p> <p>1'b0: 480-MHz Internal PLL clock<br/>1'b1: 48-MHz External Clock<br/>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.</p>                                                                           |
| 14         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 13:10      | RW          | 0x5                | <p>USBTrdTim<br/>USB Turnaround Time<br/>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+.<br/>4'h9: When the MAC interface is 8-bit UTMI+.<br/>Note: The values above are calculated for the minimum AHB frequency of 30MHz. 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.</p> |
| 9          | RW          | 0x0                | <p>HNPCap<br/>HNP-Capable<br/>The application uses this bit to control the DWC_otg core's HNP capabilities.<br/>0: HNP capability is not enabled.<br/>1: HNP capability is enabled.<br/>This bit is writable only if an HNP mode was specified for Mode of Operation (parameter OTG_MODE). Otherwise, reads return 0.</p>                                                                                                                                                                                                                                                                                                                                      |
| 8          | RW          | 0x0                | <p>SRPCap<br/>SRP-Capable<br/>The application uses this bit to control the DWC_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.<br/>0: SRP capability is not enabled.<br/>1: SRP capability is enabled.<br/>This bit is writable only if an SRP mode was specified for Mode of Operation in coreConsultant (parameter OTG_MODE). Otherwise, reads return 0.</p>                                                                                                                                                                            |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7          | RW          | 0x0                | <p><b>DDRSel</b><br/>ULPI DDR Select<br/>The application uses this bit to select a Single Data Rate (SDR) or Double Data Rate (DDR) or ULPI interface.<br/>0: Single Data Rate ULPI Interface, with 8-bit-wide data bus<br/>1: Double Data Rate ULPI Interface, with 4-bit-wide data bus</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 6          | RW          | 0x0                | <p><b>PHYSel</b><br/>USB 2.0 High-Speed PHY or USB 1.1 Full-Speed Serial Transceiver<br/>The application uses this bit to select either a high-speed UTMI+ or ULPI PHY, or a full-speed transceiver.<br/>0: USB 2.0 high-speed UTMI+ or ULPI PHY<br/>1: USB 1.1 full-speed serial transceiver<br/>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.<br/>If both interface types were selected in coreConsultant (parameters have non-zero values), the application uses this bit to select which interface is active, and access is Read and Write.</p> |
| 5          | RW          | 0x0                | <p><b>FSIntf</b><br/>Full-Speed Serial Interface Select<br/>The application uses this bit to select either a unidirectional or bidirectional USB 1.1 full-speed serial transceiver interface.<br/>0: 6-pin unidirectional full-speed serial interface<br/>1: 3-pin bidirectional full-speed serial interface<br/>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.</p>                                                                                                                    |
| 4          | RW          | 0x0                | <p><b>ULPI_UTMI_Sel</b><br/>ULPI or UTMI+ Select<br/>The application uses this bit to select either a UTMI+ interface or ULPI Interface.<br/>0: UTMI+ Interface<br/>1: ULPI Interface<br/>This bit is writable only if UTMI+ and ULPI was specified for High-Speed PHY Interface(s) in coreConsultant configuration (parameter OTG_HSPHY_INTERFACE = 3). Otherwise, reads return either 0 or 1, depending on the interface selected using the OTG_HSPHY_INTERFACE parameter.</p>                                                                                                                                                                                                                                                                                                                 |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-----|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3   | RW   | 0x0         | <p>PHYIf<br/>PHY Interface</p> <p>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.</p> <p>0: 8 bits<br/>1: 16 bits</p> <p>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.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 2:0 | RW   | 0x0         | <p>TOutCal<br/>HS/FS Timeout Calibration</p> <p>The number of PHY clocks that the application programs in this field is added to the high-speed/full-speed inter-packet 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:</p> <p>High-speed operation:</p> <ul style="list-style-type: none"> <li>One 30-MHz PHY clock = 16 bit times</li> <li>One 60-MHz PHY clock = 8 bit times</li> </ul> <p>Full-speed operation:</p> <ul style="list-style-type: none"> <li>One 30-MHz PHY clock = 0.4 bit times</li> <li>One 60-MHz PHY clock = 0.2 bit times</li> <li>One 48-MHz PHY clock = 0.25 bit times</li> </ul> |

**USBOTG\_GRSTCTL**

Address: Operational Base + offset (0x0010)

Reset Register

| Bit   | Attr | Reset Value | Description                                                                                                     |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------|
| 31    | RO   | 0x1         | <p>AHBIdle<br/>AHB Master Idle</p> <p>Indicates that the AHB Master State Machine is in the IDLE condition.</p> |
| 30    | RO   | 0x0         | <p>DMAReq<br/>DMA Request Signal</p> <p>Indicates that the DMA request is in progress. Used for debug.</p>      |
| 29:11 | RO   | 0x0         | reserved                                                                                                        |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10:6       | RW          | 0x00               | <p>TxFNum<br/>TxFIFO Number<br/>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.</p> <p>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.</p> <p>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.</p> <p>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.</p> <p>...</p> <p>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.</p> <p>5'h10: Flush all the transmit FIFOs in device or host mode.</p> |
| 5          | R/W SC      | 0x0                | <p>TxFFlsh<br/>TxFIFO Flush<br/>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 phy_clk or hclk.</p>                                                             |
| 4          | R/W SC      | 0x0                | <p>RxFFlsh<br/>Rx FIFO Flush<br/>The application can flush the entire Rx FIFO 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 Rx FIFO nor writing to the Rx FIFO. 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.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3          | R/W<br>SC   | 0x0                | INTknQFlsh<br>IN Token Sequence Learning Queue Flush<br>This bit is valid only if OTG_ENDED_TX_FIFO = 0. The application writes this bit to flush the IN Token Sequence Learning Queue.                                                             |
| 2          | W1<br>C     | 0x0                | FrmCntrRst<br>Host Frame Counter Reset<br>The application writes this bit to reset the (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. |
| 1          | R/W<br>SC   | 0x0                | Reset<br>A write to this bit issues a soft reset to the DWC_otg_power_dn module of the core.                                                                                                                                                        |

| Bit | Attr      | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----|-----------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | R/W<br>SC | 0x0         | <p>CSftRst<br/>Core Soft Reset<br/>Resets the hclk and phy_clock domains as follows: Clears the interrupts and all the CSR registers except the following register bits:</p> <ul style="list-style-type: none"> <li>CGCCTL.RstPdwnModule</li> <li>PCGCCTL.GateHclk</li> <li>PCGCCTL.PwrClmp</li> <li>PCGCCTL.StopPPhyLPwrClkSelclk</li> <li>GUSBCFG.PhyLPwrClkSel</li> <li>GUSBCFG.DDRSel</li> <li>GUSBCFG.PHYSel</li> <li>GUSBCFG.FSIntf</li> <li>GUSBCFG.ULPI_UTMI_Sel</li> <li>GUSBCFG.PHYIf</li> <li>HCFG.FSLSPclkSel</li> <li>DCFG.DevSpd</li> <li>GPIO</li> <li>GPWRDN</li> <li>GADPCTL</li> </ul> <p>All module state machines (except the AHB Slave Unit) are reset to the IDLE state, and all the transmit FIFOs and the receive FIFO are flushed. Any transactions on the AHB Master are terminated as soon as possible, after gracefully completing the last data phase of an AHB transfer. Any transactions on the USB are terminated immediately. When Hibernation or ADP feature is enabled, the PMU module is not reset by the Core Soft Reset. The application can write to this bit any time it wants to reset the core. This is a self-clearing bit and the core clears this bit after all the necessary logic is reset in the core, which can take several clocks, depending on the current state of the core. Once this bit is cleared software must wait at least 3 PHY clocks before doing any access to the PHY domain (synchronization delay). Software must also check that bit 31 of this register is 1 (AHB Master is IDLE) before starting any operation. Typically software reset is used during software development and also when you dynamically change the PHY selection bits in the USB configuration registers listed above. When you change the PHY, the corresponding clock for the PHY is selected and used in the PHY domain. Once a new clock is selected, the PHY domain has to be reset for proper operation.</p> |

**USBOTG\_GINTSTS**

Address: Operational Base + offset (0x0014)  
Interrupt Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | W1<br>C     | 0x0                | <p>WkUpInt<br/>Resume/Remote Wakeup Detected Interrupt<br/>Wakeup Interrupt during Suspend(L2) or LPM(L1) state.<br/>During Suspend(L2):<br/>Device Mode:This interrupt is asserted only when Host Initiated Resume is detected on USB.<br/>Host Mode:This interrupt is asserted only when Device Initiated Remote Wakeup is detected on USB.<br/>During LPM(L1):<br/>Device Mode:This interrupt is asserted for either Host Initiated Resume or Device Initiated Remote Wakeup on USB.<br/>Host Mode:This interrupt is asserted for either Host Initiated Resume or Device Initiated Remote Wakeup on USB.</p> |
| 30         | W1<br>C     | 0x0                | <p>SessReqInt<br/>Session Request/New Session Detected Interrupt<br/>In Host mode, this interrupt is asserted when a session request is detected from the device. In Host mode, this interrupt is asserted when a session request is detected from the device. In Device mode, this interrupt is asserted when the utmisrp_bvalid signal goes high.</p>                                                                                                                                                                                                                                                         |
| 29         | W1<br>C     | 0x0                | <p>Disconnect<br/>Disconnect Detected Interrupt<br/>This interrupt is asserted when a device disconnect is detected.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 28         | W1<br>C     | 0x0                | <p>ConIDStsChng<br/>Connector ID Status Change<br/>This interrupt is asserted when there is a change in connector ID status.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 27         | W1<br>C     | 0x0                | <p>LPM_Int<br/>LPM Transaction Received Interrupt<br/>Device Mode: This interrupt is asserted when the device receives an LPM transaction and responds with a non-ERRORed response.<br/>Host Mode: This interrupt is asserted when the device responds to an LPM transaction with a 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.</p>                                                                               |
| 26         | RO          | 0x0                | <p>PTxFEmp<br/>Periodic TxFIFO Empty<br/>This interrupt is asserted when the Periodic Transmit FIFO is either half or completely empty 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.PTxFEmpLvl).</p>                                                                                                                                                                                                                         |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 25         | RO          | 0x0                | <p>HChInt<br/>Host Channels Interrupt</p> <p>The core sets this bit to indicate that an interrupt is pending on one of the channels of the core (in Host mode). The application must read the Host All Channels Interrupt (HAINT) register to determine the exact number of the channel on which the interrupt occurred, and then read the 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.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 24         | RO          | 0x0                | <p>PrtInt<br/>Host Port Interrupt</p> <p>The core sets this bit to indicate a change in port status of one of the DWC_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.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 23         | RW          | 0x0                | <p>ResetDet<br/>Reset Detected Interrupt</p> <p>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.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 22         | W1C         | 0x0                | <p>FetSusp<br/>Data Fetch Suspended</p> <p>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, Clear 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.</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 21         | W1<br>C     | 0x0                | <p>incomIP<br/>Incomplete Periodic Transfer</p> <p>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.</p>                                  |
| 20         | W1<br>C     | 0x0                | <p>incompISOIN<br/>Incomplete Isochronous IN Transfer</p> <p>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.</p>                                                                                                                                                                                         |
| 19         | RO          | 0x0                | <p>OEPInt<br/>OUT Endpoints Interrupt</p> <p>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.</p> |
| 18         | RO          | 0x0                | <p>IEPInt<br/>IN Endpoints Interrupt</p> <p>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.</p>     |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 17         | W1<br>C     | 0x0                | EPMis<br>Endpoint Mismatch Interrupt<br>Note: This interrupt is valid only in shared FIFO operation.<br>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 application has expired. |
| 16         | W1<br>C     | 0x0                | RstrDoneInt<br>Restore Done Interrupt<br>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         | W1<br>C     | 0x0                | EOPF<br>End of Periodic Frame Interrupt<br>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         | W1<br>C     | 0x0                | ISOOutDrop<br>Isochronous OUT Packet Dropped Interrupt<br>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         | W1<br>C     | 0x0                | EnumDone<br>Enumeration Done<br>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         | W1<br>C     | 0x0                | USBRst<br>USB Reset<br>The core sets this bit to indicate that a reset is detected on the USB.                                                                                                                                                                                                                                                            |
| 11         | W1<br>C     | 0x0                | USBSusp<br>USB Suspend<br>The core sets this bit to indicate that a suspended 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.                                                                                                                         |
| 10         | W1<br>C     | 0x0                | ErlySusp<br>Early Suspend<br>The core sets this bit to indicate that an Idle state has been detected on the USB for 3ms.                                                                                                                                                                                                                                  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9          | W1C         | 0x0                | I2CINT<br>I2C Interrupt<br>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.                                                                                                                                                                                                                                                                                                                                                                    |
| 8          | W1C         | 0x0                | ULPICKINT<br>ULPI Carkit Interrupt<br>This field is used only if the Carkit interface was enabled. Otherwise, reads return 0. The core sets this interrupt when a ULPI Carkit interrupt is received. The core's PHY sets ULPI Carkit interrupt in UART or Audio mode. I2C Carkit Interrupt (I2CCKINT)<br>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          | RO          | 0x0                | GOUTNakEff<br>Global OUT NAK Effective<br>Indicates that the Set Global OUT NAK bit in the 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).                                                                                                                                                                                                                                                           |
| 6          | RO          | 0x0                | GINNakEff<br>Global IN Non-Periodic NAK Effective<br>Indicates that the Set Global Non-periodic IN NAK bit in the Device Control register (DCTL.SGNPInNak), set by the application, have taken effect in the core. That is, the core has 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. |
| 5          | RO          | 0x0                | NPTxFEmp<br>Non-Periodic Tx FIFO Empty<br>This interrupt is valid only when OTG_ENDED_TX_FIFO = 0. This interrupt is asserted when the Non-periodic Tx FIFO is either half or completely empty, and there is space for 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 Tx FIFO Empty Level bit in the Core AHB Configuration register(GAHBCFG.NPTxFEmpLvl).                                                                                                     |
| 4          | RO          | 0x0                | RxFLvl<br>Rx FIFO Non-Empty<br>Indicates that there is at least one packet pending to be read from the Rx FIFO.                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3          | W1C         | 0x0                | Sof<br>Start of (micro)Frame<br>In Host mode, the core sets this bit to indicate that an SOF (FS), micro-SOF(HS), or Keep-Alive (LS) is transmitted on the USB.<br>The application must write a 1 to this bit to clear the interrupt. 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.<br>This interrupt is seen only when the core is operating at either HS or FS. |
| 2          | RO          | 0x0                | OTGInt<br>OTG Interrupt<br>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.<br>The application must clear the appropriate status bit in the GOTGINT register to clear this bit.                                                                                                                                                                                               |
| 1          | W1C         | 0x0                | ModeMis<br>Mode Mismatch Interrupt<br>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.<br>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          | 0x0                | CurMod<br>Current Mode of Operation<br>Indicates the current mode.<br>1'b0: Device mode<br>1'b1: Host mode                                                                                                                                                                                                                                                                                                                                                                                                            |

**USBOTG\_GINTMSK**

Address: Operational Base + offset (0x0018)

Interrupt Mask Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------|
| 31         | RW          | 0x0                | WkUpIntMsk<br>Resume/Remote Wakeup Detected Interrupt Mask           |
| 30         | RW          | 0x0                | SessReqIntMsk<br>Session Request/New Session Detected Interrupt Mask |
| 29         | RW          | 0x0                | DisconnIntMsk<br>Disconnect Detected Interrupt Mask                  |
| 28         | RW          | 0x0                | ConIDStsChngMsk<br>Connector ID Status Change Mask                   |
| 27         | RW          | 0x0                | LPM_IntMsk<br>LPM Transaction Received Interrupt Mask                |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| 26         | RW          | 0x0                | PTxFEmpMsk<br>Periodic TxFIFO Empty Mask                                                                                            |
| 25         | RW          | 0x0                | HChIntMsk<br>Host Channels Interrupt Mask                                                                                           |
| 24         | RW          | 0x0                | PrtIntMsk<br>Host Port Interrupt Mask                                                                                               |
| 23         | RW          | 0x0                | ResetDetMsk<br>Reset Detected Interrupt Mask                                                                                        |
| 22         | RW          | 0x0                | FetSuspMsk<br>Data Fetch Suspended Mask                                                                                             |
| 21         | RW          | 0x0                | incomlPMsk_incompISOOUTMsk<br>Incomplete Periodic Transfer Mask(Host only)<br>Incomplete Isochronous OUT Transfer Mask(Device only) |
| 20         | RW          | 0x0                | incompISOINMsk<br>Incomplete Isochronous IN Transfer Mask                                                                           |
| 19         | RW          | 0x0                | OEPIntMsk<br>OUT Endpoints Interrupt Mask                                                                                           |
| 18         | RW          | 0x0                | IEPIntMsk<br>IN Endpoints Interrupt Mask                                                                                            |
| 17         | RW          | 0x0                | EPMisMsk<br>Endpoint Mismatch Interrupt Mask                                                                                        |
| 16         | RW          | 0x0                | RstrDoneIntMsk<br>Restore Done Interrupt Mask<br>This field is valid only when Hibernation feature is enabled.                      |
| 15         | RW          | 0x0                | EOPFMsk<br>End of Periodic Frame Interrupt Mask                                                                                     |
| 14         | RW          | 0x0                | ISOOutDropMsk<br>Isochronous OUT Packet Dropped Interrupt Mask                                                                      |
| 13         | RW          | 0x0                | EnumDoneMsk<br>Enumeration Done Mask                                                                                                |
| 12         | RW          | 0x0                | USBRstMsk<br>USB Reset Mask                                                                                                         |
| 11         | RW          | 0x0                | USBSuspMsk<br>USB Suspend Mask                                                                                                      |
| 10         | RW          | 0x0                | ErlySuspMsk<br>Early Suspend Mask                                                                                                   |
| 9          | RW          | 0x0                | I2CIntMsk<br>I2C Interrupt Mask                                                                                                     |
| 8          | RW          | 0x0                | ULPICKINTMsk_I2CCKINTMsk<br>ULPI Carkit Interrupt Mask (ULPICKINTMsk)<br>I2C Carkit Interrupt Mask (I2CCKINTMsk)                    |
| 7          | RW          | 0x0                | GOUTNakEffMsk<br>Global OUT NAK Effective Mask                                                                                      |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                        |
|------------|-------------|--------------------|-----------------------------------------------------------|
| 6          | RW          | 0x0                | GINNakEffMsk<br>Global Non-periodic IN NAK Effective Mask |
| 5          | RW          | 0x0                | NPTxFEmpMsk<br>Non-periodic TxFIFO Empty Mask             |
| 4          | RW          | 0x0                | RxFLvIMsk<br>Receive FIFO Non-Empty Mask                  |
| 3          | RW          | 0x0                | SofMsk<br>Start of (micro)Frame Mask                      |
| 2          | RW          | 0x0                | OTGIntMsk<br>OTG Interrupt Mask                           |
| 1          | RW          | 0x0                | ModeMisMsk<br>Mode Mismatch Interrupt Mask                |
| 0          | RO          | 0x0                | reserved                                                  |

**USBOTG\_GRXSTSR**

Address: Operational Base + offset (0x001c)

Receive Status Debug Read Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:25      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 24:21      | RO          | 0x0                | FN<br>Frame Number<br>(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.                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 20:17      | RO          | 0x0                | PktSts<br>Packet Status<br>Indicates the status of the received packet(Host Only)<br>4'b0010: IN data packet received<br>4'b0011: IN transfer completed (triggers an interrupt)<br>4'b0101: Data toggle error (triggers an interrupt)<br>4'b0111: Channel halted (triggers an interrupt)<br>Others: Reserved<br>Indicates the status of the received packet(Device only)<br>4'b0001: Global OUT NAK (triggers an interrupt)<br>4'b0010: OUT data packet received<br>4'b0011: OUT transfer completed (triggers an interrupt)<br>4'b0100: SETUP transaction completed (triggers an interrupt)<br>4'b0110: SETUP data packet received<br>Others: Reserved |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16:15      | RO          | 0x0                | DPID<br>Data PID<br>Indicates the Data PID of the received packet<br>2'b00: DATA0<br>2'b10: DATA1<br>2'b01: DATA2<br>2'b11: MDATA                                                                                                               |
| 14:4       | RW          | 0x000              | BCnt<br>Byte Count<br>Indicates the byte count of the received data packet.                                                                                                                                                                     |
| 3:0        | RO          | 0x0                | ChNum_EPNum<br>Channel Number(Host) Endpoint Number(Device)<br>(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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:25      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 24:21      | RO          | 0x0                | FN<br>Frame Number<br>(Device Only) This is the least significant 4 bits of the (micro)frame number in which the packet is received on the USB.<br>This field is supported only when isochronous OUT endpoints are supported.                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 20:17      | RO          | 0x0                | PktSts<br>Packet Status<br>Indicates the status of the received packet(Host Only)<br>4'b0010: IN data packet received<br>4'b0011: IN transfer completed (triggers an interrupt)<br>4'b0101: Data toggle error (triggers an interrupt)<br>4'b0111: Channel halted (triggers an interrupt)<br>Others: Reserved<br>Indicates the status of the received packet(Device only)<br>4'b0001: Global OUT NAK (triggers an interrupt)<br>4'b0010: OUT data packet received<br>4'b0011: OUT transfer completed (triggers an interrupt)<br>4'b0100: SETUP transaction completed (triggers an interrupt)<br>4'b0110: SETUP data packet received<br>Others: Reserved |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16:15      | RO          | 0x0                | DPID<br>Data PID<br>Indicates the Data PID of the received OUT data packet<br>2'b00: DATA0<br>2'b10: DATA1<br>2'b01: DATA2<br>2'b11: MDATA                                                                                                      |
| 14:4       | RO          | 0x000              | BCnt<br>Byte Count<br>Indicates the byte count of the received data packet.                                                                                                                                                                     |
| 3:0        | RO          | 0x0                | ChNum_EPNum<br>Channel Number(Host) Endpoint Number(Device)<br>(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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 15:0       | RW          | 0x0000             | RxFDep<br>RxFIFO Depth<br>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 values must not exceed the power-on value. |

**USBOTG\_GNPTXFSIZ**

Address: Operational Base + offset (0x0028)

Non-Periodic Transmit FIFO Size Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | <p>NPTxFDep<br/>Non-periodic TxFIFO<br/>For host mode, this field is always valid. For Device mode, this field is valid only when OTG_ENDED_TX_FIFO==0. This value is in terms of 32-bit words. Minimum value is 16. Maximum value is 32,768</p> <p>This field is determined by Enable Dynamic FIFO Sizing.<br/>OTG_DFIFO_DYNAMIC = 0: These flops are optimized, and reads return the power-on value.</p> <p>OTG_DFIFO_DYNAMIC = 1: The application can write a new value in this field. Programmed values must not exceed the power-on value.</p> <p>The power-on reset value of this field is specified by OTG_ENDED_TX_FIFO:<br/>OTG_ENDED_TX_FIFO = 0: The reset value is the Largest Non-periodic Tx Data FIFO Depth parameter,<br/>OTG_TX_NPERIO_DFIFO_DEPTH.<br/>OTG_ENDED_TX_FIFO = 1: The reset value is parameter OTG_TX_HNPERIO_DFIFO_DEPTH.</p> |
| 15:0       | RW          | 0x0000             | <p>NPTxFSAddr<br/>Non-periodic Transmit RAM<br/>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):<br/>OTG_DFIFO_DYNAMIC = 0: These flops are optimized, and reads return the power-on value.<br/>OTG_DFIFO_DYNAMIC = 1: The application can write a new value in this field. Programmed values must not exceed the power-on value.</p> <p>The power-on reset value of this field is specified by Largest Rx Data FIFO Depth (parameter OTG_RX_DFIFO_DEPTH).</p>                                                                                                                                                                                                                                         |

**USBOTG\_GNPTXSTS**

Address: Operational Base + offset (0x002c)

Non-Periodic Transmit FIFO/Queue Status Register

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 30:24      | RO          | 0x00               | <p>NPTxQTop<br/>Top of the Non-periodic Transmit Request Queue<br/>Entry in the Non-periodic Tx Request Queue that is currently being processed by the MAC.</p> <p>Bits [30:27]: Channel/endpoint number<br/>Bits [26:25]:<br/>2'b00: IN/OUT token<br/>2'b01: Zero-length transmit packet (device IN/host OUT)<br/>2'b10: PING/CSPLIT token<br/>2'b11: Channel halt command<br/>Bit [24]: Terminate (last entry for selected channel/endpoint)</p>              |
| 23:16      | RO          | 0x00               | <p>NPTxQSpAvail<br/>Non-periodic Transmit Request Queue Space Available<br/>Indicates the amount of free space available in the Non-periodic Transmit Request Queue. This queue holds both IN and OUT requests in Host mode. Device mode has only IN requests.</p> <p>8'h0: Non-periodic Transmit Request Queue is full<br/>8'h1: 1 location available<br/>8'h2: 2 locations available<br/>n: n locations available (0 &lt;=n &lt;= 8)<br/>Others: Reserved</p> |
| 15:0       | RO          | 0x0000             | <p>NPTxFSpAvail<br/>Non-periodic TxFIFO Space Avail<br/>Indicates the amount of free space available in the Non-periodic TxFIFO. Values are in terms of 32-bit words.</p> <p>16'h0: Non-periodic TxFIFO is full<br/>16'h1: 1 word available<br/>16'h2: 2 words available<br/>16'hn: n words available (where 0 &lt;=n &lt;=32,768)<br/>16'h8000: 32,768 words available<br/>Others: Reserved</p>                                                                |

**USBOTG\_GI2CCTL**

Address: Operational Base + offset (0x0030)

I2C Address Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | R/W SC      | 0x0                | <p>BsyDne<br/>I2C Busy/Done</p> <p>The application sets this bit to 1'b1 to start a request on the I2C interface. When the transfer is complete, the core de-asserts 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.</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 30         | RW          | 0x0                | <p>RW<br/>Read/Write Indicator<br/>Indicates whether a read or write register transfer must be performed on the interface. Read/write bursting is not supported for registers.<br/>1'b1: Read<br/>1'b0: Write</p>                                                |
| 29         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                         |
| 28         | RW          | 0x1                | <p>I2CDatSe0<br/>I2C DatSe0 USB Mode<br/>Selects the FS interface USB mode.<br/>1'b1: VP_VM USB mode<br/>1'b0: DAT_SE0 USB mode</p>                                                                                                                              |
| 27:26      | RW          | 0x0                | <p>I2CDevAdr<br/>I2C Device Address<br/>Selects the address of the I2C Slave on the USB 1.1 full-speed serial transceiver that the core uses for OTG signaling.<br/>2'b00: 7'h2C<br/>2'b01: 7'h2D<br/>2'b10: 7'h2E<br/>2'b11: 7'h2F</p>                          |
| 25         | RW          | 0x0                | <p>I2CSuspCtl<br/>I2C Suspend Control<br/>Selects how Suspend is connected to a full-speed transceiver in I2C mode.<br/>1'b0: Use the dedicated utmi_suspend_n pin<br/>1'b1: Use an I2C write to program the Suspend bit in the PHY register</p>                 |
| 24         | RO          | 0x1                | <p>Ack<br/>I2C ACK<br/>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.<br/>1'b0: NAK<br/>1'b1: ACK</p>                                   |
| 23         | RW          | 0x0                | <p>I2CEn<br/>I2C Enable<br/>Enables the I2C Master to initiate I2C transactions on the I2C interface</p>                                                                                                                                                         |
| 22:16      | RW          | 0x00               | <p>Addr<br/>I2C Address<br/>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.</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:8       | RW          | 0x00               | RegAddr<br>I2C Register Addr<br>This field programs the address of the register to be read from or written to.                                                                                                                                                                               |
| 7:0        | RW          | 0x00               | RWData<br>I2C Read/Write Data<br>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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | R/W SC      | 0x0                | DisUlpiDrv<br>Disable ULPI Drivers<br>This field is used only if the Carkit interface was enabled in coreConsultant (parameter OTG_ULPI_CARKIT = 1). Otherwise, reads return 0. The application sets this bit when it has finished processing the ULPI Carkit Interrupt (GINTSTS.ULPICKINT). When set, the DWC_otg core disables drivers for output signals and masks input signal for the ULPI interface. DWC_otg clears this bit before enabling the ULPI interface. |
| 30:28      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 27         | R/W SC      | 0x0                | VStsDone<br>VStatus Done<br>The core sets this bit when the vendor control access is done. This bit is cleared by the core when the application sets the New Register Request bit (bit 25).                                                                                                                                                                                                                                                                            |
| 26         | RO          | 0x0                | VStsBsy<br>VStatus Busy<br>The core sets this bit when the vendor control access is in progress and clears this bit when done.                                                                                                                                                                                                                                                                                                                                         |
| 25         | R/W SC      | 0x0                | NewRegReq<br>New Register Request<br>The application sets this bit for a new vendor control access.                                                                                                                                                                                                                                                                                                                                                                    |
| 24:23      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 22         | RW          | 0x0                | RegWr<br>Register Write<br>Set this bit for register writes, and clear it for register reads.                                                                                                                                                                                                                                                                                                                                                                          |
| 21:16      | RW          | 0x00               | RegAddr<br>Register Address<br>The 6-bit PHY register address for immediate PHY Register Set access. Set to 6'h2F for Extended PHY Register Set access.                                                                                                                                                                                                                                                                                                                |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:8       | RW          | 0x00               | VCtrl<br>UTMI+ Vendor Control Register Address<br>The 4-bit register address a vendor defined 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. |
| 7:0        | RW          | 0x00               | RegData<br>Register Data<br>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 Purpose Input/Output Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | GPO<br>General Purpose Output<br>This field 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<br>General Purpose Input<br>This field's read value reflects the gp_i[15:0] core input value.                                                                                                   |

**USBOTG\_GUID**

Address: Operational Base + offset (0x003c)

User ID Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                           |
|------------|-------------|--------------------|----------------------------------------------|
| 31:0       | RW          | 0x00000000         | UserID<br>Application-programmable ID field. |

**USBOTG\_GSNPSID**

Address: Operational Base + offset (0x0040)

Core ID Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                              |
|------------|-------------|--------------------|-------------------------------------------------|
| 31:0       | RO          | 0x00004f54         | CoreID<br>Release number of the core being used |

**USBOTG\_GHWCFG1**

Address: Operational Base + offset (0x0044)

User HW Config1 Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | <p>epdir<br/>Endpoint Direction<br/>This 32-bit field uses two bits per endpoint to determine the endpoint direction.</p> <p>Endpoint<br/>Bits [31:30]: Endpoint 15 direction<br/>Bits [29:28]: Endpoint 14 direction<br/>...<br/>Bits [3:2]: Endpoint 1 direction<br/>Bits[1:0]: Endpoint 0 direction (always BIDIR)</p> <p>Direction<br/>2'b00: BIDIR (IN and OUT) endpoint<br/>2'b01: IN endpoint<br/>2'b10: OUT endpoint<br/>2'b11: Reserved</p> |

**USBOTG\_GHWCFG2**

Address: Operational Base + offset (0x0048)

User HW Config2 Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RO          | 0x0                | <p>OTG_ENABLE_IC_USB<br/>IC_USB mode specified for mode of operation (parameter OTG_ENABLE_IC_USB). To choose IC_USB_MODE, both OTG_FSPHY_INTERFACE and OTG_ENABLE_IC_USB must be 1.</p> |
| 30:26      | RO          | 0x00               | <p>TknQDepth<br/>Device Mode IN Token Sequence Learning Queue Depth<br/>Range: 0-30</p>                                                                                                  |
| 25:24      | RO          | 0x0                | <p>PTxQDepth<br/>Host Mode Periodic Request Queue Depth<br/>2'b00: 2<br/>2'b01: 4<br/>2'b10: 8<br/>Others: Reserved</p>                                                                  |
| 23:22      | RO          | 0x0                | <p>NPTxQDepth<br/>Non-periodic Request Queue Depth<br/>2'b00: 2<br/>2'b01: 4<br/>2'b10: 8<br/>Others: Reserved</p>                                                                       |
| 21         | RO          | 0x0                | reserved                                                                                                                                                                                 |
| 20         | RO          | 0x0                | <p>MultiProcIntrpt<br/>Multi Processor Interrupt Enabled<br/>1'b0: No<br/>1'b1: Yes</p>                                                                                                  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 19         | RO          | 0x0                | DynFifoSizing<br>Dynamic FIFO Sizing Enabled<br>1'b0: No<br>1'b1: Yes                                                                                                                                             |
| 18         | RO          | 0x0                | PerioSupport<br>Periodic OUT Channels Supported in Host Mode<br>1'b0: No<br>1'b1: Yes                                                                                                                             |
| 17:14      | RO          | 0x0                | NumHstChnl<br>Number of Host Channels<br>Indicates the number of host channels supported by the core in Host mode. The range of this field is 0-15: 0 specifies 1 channel, 15 specifies 16 channels.              |
| 13:10      | RO          | 0x0                | NumDevEps<br>Number of Device Endpoints<br>Indicates the number of device endpoints supported by the core in Device mode in addition to control endpoint 0. The range of this field is 1-15.                      |
| 9:8        | RO          | 0x0                | FSPhyType<br>Full-Speed PHY Interface Type<br>2'b00: Full-speed interface not supported<br>2'b01: Dedicated full-speed interface<br>2'b10: FS pins shared with UTMI+ pins<br>2'b11: FS pins shared with ULPI pins |
| 7:6        | RO          | 0x0                | HSPhyType<br>High-Speed PHY Interface Type<br>2'b00: High-Speed interface not supported<br>2'b01: UTMI+<br>2'b10: ULPI<br>2'b11: UTMI+ and ULPI                                                                   |
| 5          | RO          | 0x0                | SingPnt<br>Point-to-Point<br>1'b0: Multi-point application (hub and split support)<br>1'b1: Single-point application (no hub and no split support)                                                                |
| 4:3        | RO          | 0x0                | OtgArch<br>Architecture<br>2'b00: Slave-Only<br>2'b01: External DMA<br>2'b10: Internal DMA<br>Others: Reserved                                                                                                    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:0        | RO          | 0x0                | <p>OtgMode<br/>Mode of Operation</p> <p>3'b000: HNP- and SRP-Capable OTG (Host and Device)<br/>3'b001: SRP-Capable OTG (Host and Device)<br/>3'b010: Non-HNP and Non-SRP Capable OTG (Host and Device)<br/>3'b011: SRP-Capable Device<br/>3'b100: Non-OTG Device<br/>3'b101: SRP-Capable Host<br/>3'b110: Non-OTG Host<br/>Others: Reserved</p> |

**USBOTG\_GHWCFG3**

Address: Operational Base + offset (0x004c)

User HW Config3 Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | <p>DfifoDepth<br/>DFIFO Depth</p> <p>This value is in terms of 32-bit words.</p> <p>Minimum value is 32</p> <p>Maximum value is 32,768</p>                                                                                               |
| 15         | RO          | 0x0                | <p>OTG_ENABLE_LPM</p> <p>LPM mode specified for Mode of Operation (parameter OTG_ENABLE_LPM).</p>                                                                                                                                        |
| 14         | RO          | 0x0                | <p>OTG_BC_SUPPORT</p> <p>This bit indicates the HS OTG controller support for Battery Charger.</p> <p>0 : No Battery Charger Support<br/>1 : Battery Charger support present.</p>                                                        |
| 13         | RO          | 0x0                | <p>OTG_ENABLE_HSIC</p> <p>HSIC mode specified for Mode of Operation (parameter OTG_ENABLE_HSIC).</p> <p>Value Range: 0-1</p> <p>1: HSIC-capable with shared UTMI PHY interface<br/>0: Non-HSIC-capable</p>                               |
| 12         | RO          | 0x0                | <p>OTG_AD_P_SUPPORT</p> <p>This bit indicates whether ADP logic is present within or external to the HS OTG controller</p> <p>0: No ADP logic present with HSOTG controller<br/>1: ADP logic is present along with HSOTG controller.</p> |
| 11         | RO          | 0x0                | <p>RstType</p> <p>Reset Style for Clocked always Blocks in RTL</p> <p>1'b0: Asynchronous reset is used in the core<br/>1'b1: Synchronous reset is used in the core</p>                                                                   |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10         | RO          | 0x0                | OptFeature<br>Optional Features Removed<br>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?<br>1'b0: No<br>1'b1: Yes |
| 9          | RO          | 0x0                | VndctlSupt<br>Vendor Control Interface Support<br>1'b0: Vendor Control Interface is not available on the core.<br>1'b1: Vendor Control Interface is available.                                                                                    |
| 8          | RO          | 0x0                | I2CIntSel<br>I2C Selection<br>1'b0: I2C Interface is not available on the core.<br>1'b1: I2C Interface is available on the core.                                                                                                                  |
| 7          | RO          | 0x0                | OtgEn<br>OTG Function Enabled<br>The application uses this bit to indicate the DWC_otg core's OTG capabilities.<br>1'b0: Not OTG capable<br>1'b1: OTG Capable                                                                                     |
| 6:4        | RO          | 0x0                | PktSizeWidth<br>Width of Packet Size Counters<br>3'b000: 4 bits<br>3'b001: 5 bits<br>3'b010: 6 bits<br>3'b011: 7 bits<br>3'b100: 8 bits<br>3'b101: 9 bits<br>3'b110: 10 bits<br>Others: Reserved                                                  |
| 3:0        | RO          | 0x0                | XferSizeWidth<br>Width of Transfer Size Counters<br>4'b0000: 11 bits<br>4'b0001: 12 bits<br>...<br>4'b1000: 19 bits<br>Others: Reserved                                                                                                           |

**USBOTG\_GHWCFG4**

Address: Operational Base + offset (0x0050)  
 User HW Config4 Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RO          | 0x0                | SGDMA<br>Scatter/Gather DMA<br>1'b1: Dynamic configuration                                                                                                                        |
| 30         | RO          | 0x0                | SGDMACon<br>Scatter/Gather DMA configuration<br>1'b0: Non-Scatter/Gather DMA configuration<br>1'b1: Scatter/Gather DMA configuration                                              |
| 29:26      | RO          | 0x0                | INEps<br>Number of Device Mode IN Endpoints Including Control Endpoint<br>Range 0 -15<br>0:1 IN Endpoint<br>1:2 IN Endpoints<br>....<br>15:16 IN Endpoints                        |
| 25         | RW          | 0x0                | DedFifoMode<br>Enable Dedicated Transmit FIFO for device IN Endpoints<br>1'b0: Dedicated Transmit FIFO Operation not enabled.<br>1'b1: Dedicated Transmit FIFO Operation enabled. |
| 24         | RW          | 0x0                | SessEndFltr<br>session_end Filter Enabled<br>1'b0: No filter<br>1'b1: Filter                                                                                                      |
| 23         | RW          | 0x0                | BValidFltr<br>"b_valid" Filter Enabled<br>1'b0: No filter<br>1'b1: Filter                                                                                                         |
| 22         | RO          | 0x0                | AValidFltr<br>"a_valid" Filter Enabled<br>1'b0: No filter<br>1'b1: Filter                                                                                                         |
| 21         | RO          | 0x0                | VBusValidFltr<br>"vbus_valid" Filter Enabled<br>1'b0: No filter<br>1'b1: Filter                                                                                                   |
| 20         | RO          | 0x0                | IddgFltr<br>"iddig" Filter Enable<br>1'b0: No filter<br>1'b1: Filter                                                                                                              |
| 19:16      | RO          | 0x0                | NumCtlEps<br>Number of Device Mode Control Endpoints in Addition to Endpoint<br>Range: 0-15                                                                                       |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:14      | RO          | 0x0                | PhyDataWidth<br>UTMI+ PHY/ULPI-to-Internal UTMI+ Wrapper Data Width<br>When a ULPI PHY is used, an internal wrapper converts ULPI to UTMI+.<br>2'b00: 8 bits<br>2'b01: 16 bits<br>2'b10: 8/16 bits, software selectable<br>Others: Reserved |
| 13:7       | RO          | 0x0                | reserved                                                                                                                                                                                                                                    |
| 6          | RO          | 0x0                | EnHiber<br>Enable Hibernation<br>1'b0: Hibernation feature not enabled<br>1'b1: Hibernation feature enabled                                                                                                                                 |
| 5          | RO          | 0x0                | AhbFreq<br>Minimum AHB Frequency Less Than 60 MHz<br>1'b0: No<br>1'b1: Yes                                                                                                                                                                  |
| 4          | RO          | 0x0                | EnParPwrDown<br>Enable Partial Power Down<br>1'b0: Partial Power Down Not Enabled<br>1'b1: Partial Power Down Enabled                                                                                                                       |
| 3:0        | RO          | 0x0                | NumDevPerioEps<br>Number of Device Mode Periodic IN Endpoints<br>Range: 0-15                                                                                                                                                                |

**USBOTG\_GLPMCFG**

Address: Operational Base + offset (0x0054)  
Core LPM Configuration Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RW          | 0x0                | <p>InvSelHsic<br/>HSIC-Invert Select HSIC</p> <p>The application uses this bit to control the DWC_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 is 1:</p> <ul style="list-style-type: none"> <li>1'b1: HSIC capability is not enabled.</li> <li>1'b0: HSIC capability is enabled,</li> </ul> <p>If InvSelHsic = 1'b0: HSIC capability is enabled. If the if_sel_hsic input signal is 0:</p> <ul style="list-style-type: none"> <li>1'b1: HSIC capability is enabled,</li> <li>1'b0: HSIC capability is not enabled.</li> </ul> <p>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.</p> |
| 30         | RW          | 0x0                | <p>HSICCon<br/>HSIC-Connect</p> <p>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 &amp; DATA = 0) on the bus. It then waits for the device to initiate 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.</p>                                                                                                                                                                                                                                                                                                                                                                  |
| 29:28      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 27:25      | RO          | 0x0                | <p>LPM_RetryCnt_Sts<br/>LPM Retry Count Status</p> <p>Number of LPM host retries remaining to be transmitted for the current LPM sequence.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 24         | RW          | 0x0                | <p>SndLPM<br/>Send LPM Transaction</p> <p>Host Mode: When the application software sets this bit, an LPM transaction containing two tokens, EXT and LPM, is sent. The hardware 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 to a local port.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23:21      | R/W<br>SC   | 0x0                | LPM_Retry_Cnt<br>LPM Retry Count<br>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.                                                                                                                                                                                                 |
| 20:17      | RW          | 0x0                | LPM_Chnl_Idx<br>LPM Channel Index<br>The channel number on which the LPM transaction must be applied while sending an 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.                                                                                |
| 16         | RO          | 0x0                | L1ResumeOK<br>Sleep State Resume OK<br>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 mode after a delay of 50 us (TL1Residency). The bit is reset when SlpSts is 0<br>1'b1: The application/core can start resume from the Sleep state<br>1'b0: The application/core cannot start resume from the Sleep state |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15         | RO          | 0x0                | <p>SlpSts<br/>Port Sleep Status</p> <p>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.</p> <p>The core comes out of sleep:</p> <p>When there is any activity on the USB line_state,</p> <p>When the application writes to the Remote Wakeup Signaling bit in the Device Control register (DCTL.RmtWkUpSig) or when the application resets or soft-disconnects the device.</p> <p>Host Mode: The host transitions to the Sleep (L1) state as a side-effect 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:</p> <p>The core detects a remote L1 Wakeup signal,</p> <p>The application sets the Port Reset bit or the Port L1Resume bit in the HPRT register or The application sets the L1Resume/ Remote Wakeup Detected Interrupt bit or Disconnect Detected Interrupt bit in the Core Interrupt register (GINTSTS.L1WkUpInt or GINTSTS.DisconnInt, respectively).</p> <p>Values:</p> <p>1'b0: Core not in L1</p> <p>1'b1: Core in L1</p> |
| 14:13      | RO          | 0x0                | <p>CoreL1Res<br/>LPM Response</p> <p>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.</p> <p>11: ACK<br/>10: NYET<br/>01: STALL<br/>00: ERROR (No handshake response)</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                              |                                                                                                                         |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|
| 12:8       | RW          | 0x00               | HIRD_Thres<br>HIRD Threshold<br>Device Mode: The core asserts L1SuspendM to put the PHY into Deep Low-Power mode in L1 when the HIRD value is greater than or equal to the value defined in this field (GLPMCFG.HIRD_Thres[3:0]), and HIRD_Thres[4] is set to 1'b1.<br>Host Mode: The core asserts L1SuspendM to put the PHY into Deep Low-Power mode in L1 when HIRD_Thres[4] is set to 1'b1. HIRD_Thres[3:0] specifies the time for which resume signaling is to be reflected by the host TL1HubDrvResume2) on the USB when it detects device-initiated resume. HIRD_Thres must not be programmed with a value greater than 4'b1100 in Host mode, because this exceeds maximum TL1HubDrvResume2.<br>Sl. No HIRD_Thres[3:0]      Host mode resume time(us) | 4'b0000<br>4'b0001<br>4'b0010<br>4'b0011<br>4'b0100<br>4'b0101<br>4'b0110<br>4'b0111<br>4'b1000<br>4'b1001<br>4'b1010<br>4'b1011<br>4'b1100<br>4'b1101<br>4'b1110<br>4'b1111 | 60<br>135<br>210<br>285<br>360<br>435<br>510<br>585<br>660<br>735<br>810<br>885<br>960<br>invalid<br>invalid<br>invalid |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7          | RW          | 0x0                | <p>EnbISlpM<br/>Enable utmi_sleep_n</p> <p>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.</p> <p>1'b0: Writes to the ULPI Function Control Bit[7] are disabled.<br/>1'b1: The core is enabled to write to the ULPI Function Control Bit[7], which enables the PHY to enter Low-Power mode.</p> <p>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 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 interface, 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.</p> <p>1'b0: utmi_sleep_n assertion from the core is not transferred to the external PHY.<br/>1'b1: utmi_sleep_n assertion from the core is transferred to the external PHY when utmi_l1_suspend_n cannot be asserted.</p> |
| 6          | RW          | 0x0                | <p>bRemoteWake<br/>RemoteWakeEnable</p> <p>Host Mode: The remote wakeup value to be 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.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |        |           |            |   |         |    |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |    |         |     |    |         |     |    |         |     |    |         |     |    |         |      |    |         |      |    |         |      |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-----------|------------|---|---------|----|---|---------|-----|---|---------|-----|---|---------|-----|---|---------|-----|---|---------|-----|---|---------|-----|---|---------|-----|---|---------|-----|----|---------|-----|----|---------|-----|----|---------|-----|----|---------|-----|----|---------|------|----|---------|------|----|---------|------|
| 5:2        | RW          | 0x0                | <p>HIRD<br/>Host-Initiated Resume Duration<br/>Host Mode: The value of HIRD to be sent in an LPM transaction.<br/>This value is also used to initiate resume for a durationL1HubDrvResume1 for host initiated resume. Device Mode: This field is updated with the Received LPM Token HIRD bmAttribute when an ACK/NYET/STALL response is sent to an LPM transaction</p> <table> <thead> <tr> <th>SI. No</th> <th>HIRD[3:0]</th> <th>THIRD (us)</th> </tr> </thead> <tbody> <tr><td>1</td><td>4'b0000</td><td>50</td></tr> <tr><td>2</td><td>4'b0001</td><td>125</td></tr> <tr><td>3</td><td>4'b0010</td><td>200</td></tr> <tr><td>4</td><td>4'b0011</td><td>275</td></tr> <tr><td>5</td><td>4'b0100</td><td>350</td></tr> <tr><td>6</td><td>4'b0101</td><td>425</td></tr> <tr><td>7</td><td>4'b0110</td><td>500</td></tr> <tr><td>8</td><td>4'b0111</td><td>575</td></tr> <tr><td>9</td><td>4'b1000</td><td>650</td></tr> <tr><td>10</td><td>4'b1001</td><td>725</td></tr> <tr><td>11</td><td>4'b1010</td><td>800</td></tr> <tr><td>12</td><td>4'b1011</td><td>875</td></tr> <tr><td>13</td><td>4'b1100</td><td>950</td></tr> <tr><td>14</td><td>4'b1101</td><td>1025</td></tr> <tr><td>15</td><td>4'b1110</td><td>1100</td></tr> <tr><td>16</td><td>4'b1111</td><td>1175</td></tr> </tbody> </table> | SI. No | HIRD[3:0] | THIRD (us) | 1 | 4'b0000 | 50 | 2 | 4'b0001 | 125 | 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 |
| SI. No     | HIRD[3:0]   | THIRD (us)         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |        |           |            |   |         |    |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |    |         |     |    |         |     |    |         |     |    |         |     |    |         |      |    |         |      |    |         |      |
| 1          | 4'b0000     | 50                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |        |           |            |   |         |    |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |    |         |     |    |         |     |    |         |     |    |         |     |    |         |      |    |         |      |    |         |      |
| 2          | 4'b0001     | 125                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |        |           |            |   |         |    |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |    |         |     |    |         |     |    |         |     |    |         |     |    |         |      |    |         |      |    |         |      |
| 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               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |        |           |            |   |         |    |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |    |         |     |    |         |     |    |         |     |    |         |     |    |         |      |    |         |      |    |         |      |
| 1          | RW          | 0x0                | <p>AppL1Res<br/>LPM response programmed by application<br/>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:<br/>1: ACK. Even though an ACK is pre-programmed, the core responds with an ACK only on a successful LPM transaction. The 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)<br/>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).</p>                                                                                                                                                                                                                                                                                                                                                  |        |           |            |   |         |    |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |    |         |     |    |         |     |    |         |     |    |         |     |    |         |      |    |         |      |    |         |      |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0          | RW          | 0x0                | <p>LPMCap<br/>LPM-Capable</p> <p>The application uses this bit to control the DWC_otg core LPM capabilities. If the core operates as a non-LPM-capable host, it cannot request the connected device/hub to activate LPM mode. If the core operates as a non-LPM-capable device, it cannot respond to any LPM transactions.</p> <p>1'b0: LPM capability is not enabled.<br/>1'b1: LPM capability is enabled.</p> <p>This bit is writable only if an LPM mode was specified for Mode of Operation (parameter OTG_ENABLE_LPM). Otherwise, reads return 0.</p> |

**USBOTG\_GPWRDN**

Address: Operational Base + offset (0x0058)

Global Power Down Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:29      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                     |
| 28:24      | RO          | 0x00               | <p>MultValIdBC<br/>Multi Valued ID pin<br/>Battery Charger ACA inputs in the following order:<br/>Bit 26 - rid_float.<br/>Bit 25 - rid_gnd<br/>Bit 24 - rid_a<br/>Bit 23 - rid_b<br/>Bit 22 - rid_c</p> <p>These bits are present only if OTG_BC_SUPPORT = 1.<br/>Otherwise, these bits are reserved and will read 5'h0.</p> |
| 23         | W1C         | 0x0                | <p>ADPInt<br/>ADP Interupt<br/>This bit is set whenever there is a ADP event.</p>                                                                                                                                                                                                                                            |
| 22         | RO          | 0x0                | <p>BSessVld<br/>B Session Valid<br/>This field reflects the B session valid status signal from the PHY.<br/>1'b0: B-Valid is 0.<br/>1'b1: B-Valid is 1.<br/>This bit is valid only when GPWRDN.PMUActv is 1.</p>                                                                                                             |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 21         | RO          | 0x0                | <p><b>IDDIG</b><br/>           This bit indicates the status of the signal IDDIG. The application must read this bit after receiving GPWRDN.StsChngInt and decode based on the previous value stored by the application.<br/>           Indicates the current mode.<br/>           1'b1: Device mode<br/>           1'b0: Host mode<br/>           This bit is valid only when GPWRDN.PMUActv is 1.</p>         |
| 20:19      | RO          | 0x0                | <p><b>LineState</b><br/>           This field indicates the current linestate on USB as seen by the PMU module.<br/>           2'b00: DM = 0, DP = 0.<br/>           2'b01: DM = 0, DP = 1.<br/>           2'b10: DM = 1, DP = 0.<br/>           2'b11: Not-defined.<br/>           This bit is valid only when GPWRDN.PMUActv is 1.</p>                                                                        |
| 18         | RW          | 0x0                | <p><b>StsChngIntMsk</b><br/>           Mask For StsChng Interrupt</p>                                                                                                                                                                                                                                                                                                                                           |
| 17         | W1C         | 0x0                | <p><b>StsChngInt</b><br/>           This field indicates a status change in either the IDDIG or BSessVld signal.<br/>           1'b0: No Status change<br/>           1'b1: status change detected<br/>           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.</p> |
| 16         | RW          | 0x0                | <p><b>SRPDetectMsk</b><br/>           Mask For SRPDetect Interrupt</p>                                                                                                                                                                                                                                                                                                                                          |
| 15         | W1C         | 0x0                | <p><b>SRPDetect</b><br/>           This field indicates that SRP has been detected by the PMU. This field generates an interrupt. After detecting SRP during hibernation the application should not restore the core. The application should get into the initialization process.<br/>           1'b0: SRP not detected<br/>           1'b1: SRP detected</p>                                                   |
| 14         | RW          | 0x0                | <p><b>ConnDetMsk</b><br/>           Mask for ConnectDet interrupt<br/>           This bit is valid only when OTG_EN_PWROPT = 2.</p>                                                                                                                                                                                                                                                                             |
| 13         | W1C         | 0x0                | <p><b>ConnectDet</b><br/>           This field indicates that a new connect has been detected<br/>           1'b0: Connect not detected<br/>           1'b1: Connect detected<br/>           This bit is valid only when OTG_EN_PWROPT = 2.</p>                                                                                                                                                                 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12         | RW          | 0x0                | DisconnectDetectMsk<br>Mask For DisconnectDetect Interrupt<br>This bit is valid only when OTG_EN_PWRROPT = 2.                                                                                                                                                                                                                                                                       |
| 11         | W1C         | 0x0                | DisconnectDetect<br>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.<br>1'b0: Disconnect not detected<br>1'b1: Disconnect detected<br>This bit is valid only when OTG_EN_PWRROPT = 2.   |
| 10         | RW          | 0x0                | ResetDetMsk<br>Mask For ResetDetected interrupt. This bit is valid only when OTG_EN_PWRROPT = 2.                                                                                                                                                                                                                                                                                    |
| 9          | W1C         | 0x0                | ResetDetected<br>This field indicates that Reset has been detected by the PMU module. This field generates an interrupt.<br>1'b0: Reset Not Detected<br>1'b1: Reset Detected<br>This bit is valid only when OTG_EN_PWRROPT = 2.                                                                                                                                                     |
| 8          | RW          | 0x0                | LineStageChangeMsk<br>Mask For LineStageChange interrupt<br>This bit is valid only when OTG_EN_PWRROPT = 2.                                                                                                                                                                                                                                                                         |
| 7          | W1C         | 0x0                | LnStsChng<br>Line State Change<br>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.<br>1'b0: No LineState change on USB<br>1'b1: LineState change on USB<br>This bit is valid only when GPWRDN.PMUActv is 1. This bit is valid only when OTG_EN_PWRROPT = 2. |
| 6          | RW          | 0x0                | DisableVBUS<br>The application should program this bit if HPRT0.PrtPwr was programmed to 0 before entering Hibernation. This is to indicate PMU whether session was ended before entering Hibernation.<br>1'b0: HPRT0.PrtPwr was not programmed to 0.<br>1'b1: HPRT0.PrtPwr was programmed to 0.                                                                                    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5          | RW          | 0x0                | <p>PwrDnSwtch<br/>Power Down Switch<br/>This bit indicates to the DWC_otg core VDD switch is in ON/OFF state<br/>1'b0: DWC_otg is in ON state<br/>1'b1: DWC_otg is in OFF state<br/><i>Note: This bit must not be written to during normal mode of operation.</i></p>                                                                                                                                     |
| 4          | RW          | 0x0                | <p>PwrDnRst_n<br/>Power Down ResetN<br/>The application must program this bit to reset the DWC OTG core during the Hibernation exit process or during ADP when powering up the core (in case the DWC OTG core was powered off during ADP process).<br/>1'b1: DWC_otg is in normal operation<br/>1'b0: reset DWC_otg<br/><i>Note: This bit must not be written to during normal mode of operation.</i></p> |
| 3          | RW          | 0x0                | <p>PwrDnClmp<br/>Power Down Clamp<br/>The application must program this bit to enable or disable the clamps to all the outputs of the DWC OTG core module to prevent the corruption of other active logic.<br/>1'b0: Disable PMU power clamp<br/>1'b1: Enable PMU power clamp</p>                                                                                                                         |
| 2          | RW          | 0x0                | <p>Restore<br/>The application should program this bit to enable or disable restore mode from the PMU module.<br/>1'b0: DWC_otg in normal mode of operation<br/>1'b1: DWC_otg in restore mode<br/><i>Note: This bit must not be written to during normal mode of operation. This bit is valid only when OTG_EN_PWROPT = 2.</i></p>                                                                        |
| 1          | RW          | 0x0                | <p>PMUActv<br/>PMU Active<br/>This is bit is to enable or disable the PMU logic.<br/>1'b0: Disable PMU module<br/>1'b1: Enable PMU module<br/><i>Note: This bit must not be written to during normal mode of operation.</i></p>                                                                                                                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0          | RW          | 0x0                | <p>PMUIntSel<br/>PMU Interrupt Select<br/>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 the application. During this state all interrupts from the core module are blocked to the application. Note: This bit must be set to 1'b1 before the core is put into hibernation</p> <p>1'b0: Internal DWC_otg_core interrupt is selected<br/>1'b1: the external DWC_otg_pmu interrupt is selected<br/>Note: This bit must not be written to during normal mode of operation.</p> |

**USBOTG\_GDFIFO CFG**

Address: Operational Base + offset (0x005c)

Global DFIFO Software Config Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | EPIInfoBaseAddr<br>This field provides the start address of the EP info controller.                                                                                                                                                                            |
| 15:0       | RW          | 0x0000             | GDFIFO Cfg<br>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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:29      | RO          | 0x0                | reserved                                                                                                                                                                            |
| 28:27      | R/W SC      | 0x0                | <p>AR<br/>Access Request<br/>2'b00 Read/Write Valid (updated by the core)<br/>2'b01 Read<br/>2'b10 Write<br/>2'b11 Reserved</p>                                                     |
| 26         | RW          | 0x0                | <p>AdpTmoutMsk<br/>ADP Timeout Interrupt Mask<br/>When this bit is set, it unmasks the interrupt because of AdpTmoutInt. This bit is valid only if OTG_Ver = 1'b1(GOTGCTL[20]).</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 25         | RW          | 0x0                | AdpSnsIntMsk<br>ADP Sense Interrupt Mask<br>When this bit is set, it unmasks the interrupt due to AdpSnsInt.<br>This bit is valid only if OTG_Ver = 1'b1(GOTGCTL[20]).                                                                                                                                                                     |
| 24         | RW          | 0x0                | AdpPrbIntMsk<br>ADP Probe Interrupt Mask<br>When this bit is set, it unmasks the interrupt due to AdpPrbInt.This bit is valid only if OTG_Ver = 1'b1(GOTGCTL[20]).                                                                                                                                                                         |
| 23         | W1C         | 0x0                | AdpTmoutInt<br>ADP Timeout Interrupt<br>This bit is relevant only for an ADP probe. When this bit is set, it means that the ramp time has completed (GADPCTL.RTIM has 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. |
| 22         | W1C         | 0x0                | AdpSnsInt<br>ADP Sense Interrupt<br>When this bit is set, it means that the VBUS voltage is greater than VadpSns value or VadpSns is reached. This bit is valid only if OTG_Ver = 1'b1 (GOTGCTL[20]).                                                                                                                                      |
| 21         | W1C         | 0x0                | AdpPrbInt<br>ADP Probe Interrupt<br>When this bit is set, it means that the VBUS voltage is greater than VadpPrb or VadpPrb is reached. This bit is valid only if OTG_Ver = 1'b1 (GOTGCTL[20]).                                                                                                                                            |
| 20         | RW          | 0x0                | ADPEn<br>ADP Enable When set, the core performs either ADP probing or sensing based on EnaPrb or EnaSns. This bit is valid only if OTG_Ver = 1'b1 (GOTGCTL[20]).                                                                                                                                                                           |
| 19         | R/W SC      | 0x0                | ADPRes<br>ADP Reset<br>When set, ADP controller is reset. This bit is auto-cleared after the reset procedure is complete in ADP controller.This bit is valid only if OTG_Ver = 1'b1 (GOTGCTL[20]).                                                                                                                                         |
| 18         | RW          | 0x0                | EnaSns<br>Enable Sense<br>When programmed to 1'b1, the core performs a sense operation.<br>This bit is valid only if OTG_Ver = 1'b1 (GOTGCTL[20]).                                                                                                                                                                                         |
| 17         | RW          | 0x0                | EnaPrb<br>Enable Probe<br>When programmed to 1'b1, the core performs a probe operation.<br>This bit is valid only if OTG_Ver = 1'b1 (GOTGCTL[20]).                                                                                                                                                                                         |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16:6       | RO          | 0x000              | <p>RTIM<br/>RAMP TIME<br/>These bits capture the latest time it took for VBUS to ramp from VADP_SINK to VADP_PRB. The bits are defined in units of 32 kHz clock cycles as follows:<br/>0x000 - 1 cycles<br/>0x001 - 2 cycles<br/>0x002 - 3 cycles<br/>and so on till<br/>0x7FF - 2048 cycles<br/>A time of 1024 cycles at 32 kHz corresponds to a time of 32 msec.<br/>(Note for scaledown ramp_timeout =<br/>prb_delta == 2'b00 =&gt; 200 cycles<br/>prb_delta == 2'b01 =&gt; 100 cycles<br/>prb_delta == 2'b01 =&gt; 50 cycles<br/>prb_delta == 2'b01 =&gt; 25 cycles.)</p> |
| 5:4        | RW          | 0x0                | <p>PrbPer<br/>Probe Period<br/>These bits sets the TadpPrd as follows:<br/>2'b00 - 0.625 to 0.925 sec (typical 0.775 sec)<br/>2'b01 - 1.25 to 1.85 sec (typical 1.55 sec)<br/>2'b10 - 1.9 to 2.6 sec (typical 2.275 sec)<br/>2'b11 - Reserved<br/>(PRB_PER is also scaledown<br/>prb_per== 2'b00 =&gt; 400 ADP clocks<br/>prb_per== 2'b01 =&gt; 600 ADP clocks<br/>prb_per== 2'b10 =&gt; 800 ADP clocks<br/>prb_per==2'b11 =&gt; 1000 ADP clocks)</p>                                                                                                                         |
| 3:2        | RW          | 0x0                | <p>PrbDelta<br/>Probe Delta<br/>These bits set the resolution for RTIM value. The bits are defined in units of 32 kHz clock cycles as follows:<br/>2'b00 - 1 cycles<br/>2'b01 - 2 cycles<br/>2'b10 - 3 cycles<br/>2'b11 - 4 cycles<br/>For example if this value is chosen to 2'b01, it means that RTIM increments forevery three 32Khz clock cycles.</p>                                                                                                                                                                                                                     |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0        | RW          | 0x0                | <p>PrbDschg<br/>Probe Discharge</p> <p>These bits set the times for TadpDschg. These bits are defined as follows:</p> <ul style="list-style-type: none"> <li>2'b00 4 msec (Scaledown 2 32Khz clock cycles)</li> <li>2'b01 8 msec (Scaledown 4 32Khz clock cycles)</li> <li>2'b10 16 msec (Scaledown 8 32Khz clock cycles)</li> <li>2'b11 32 msec (Scaledown 16 32Khz clock cycles)</li> </ul> |

**USBOTG\_HPTXFSIZ**

Address: Operational Base + offset (0x0100)

Host Periodic Transmit FIFO Size Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | <p>PTxFSize<br/>Host Periodic TxFIFO Depth</p> <p>This value is in terms of 32-bit words.</p> <p>Minimum value is 16</p> <p>Maximum value is 32,768</p> <p>The power-on reset value of this register is specified as the Largest Host Mode Periodic Tx Data FIFO Depth (parameter OTG_TX_HPERIO_DFIFO_DEPTH). If Enable Dynamic FIFO Sizing was deselected (parameter OTG_DFIFO_DYNAMIC = 0), these 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 set.</p>                                                                                                            |
| 15:0       | RW          | 0x0000             | <p>PTxFSAddr<br/>Host Periodic TxFIFO Start Address</p> <p>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.</p> <p>These parameters are:</p> <p>In shared FIFO operation:<br/>OTG_RX_DFIFO_DEPTH + OTG_TX_NPERIO_DFIFO_DEPTH.</p> <p>In dedicated FIFO mode:<br/>OTG_RX_DFIFO_DEPTH + OTG_TX_HNPERIO_DFIFO_DEPTH.</p> <p>If Enable Dynamic FIFO Sizing was deselected (parameter OTG_DFIFO_DYNAMIC = 0), these flops are optimized, and reads return the power-on value.</p> <p>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.</p> |

**USBOTG\_DIEPTXFn**

Address: Operational Base + offset (0x0104)

Device Periodic Transmit FIFO-n Size Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | <p>INEP1TxFDep<br/>IN Endpoint TxFIFO Depth<br/>This value is in terms of 32-bit words.<br/>Minimum value is 16<br/>Maximum value is 32,768</p> <p>The power-on reset value of this register is specified as the Largest IN Endpoint FIFO number Depth (parameter OTG_TX_DINEP_DFIFO_DEPTH_n)(0 &lt; n &lt;= 15). If Enable Dynamic FIFO Sizing was deselected (parameter OTG_DFIFO_DYNAMIC = 0), these flops are optimized, and reads return the power-on value.</p> <p>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.</p>                                                                                                                                                                                                                                                                                                                               |
| 15:0       | RW          | 0x0000             | <p>INEP1TxFStAddr<br/>IN Endpoint FIFO1 Transmit RAM Start Address<br/>This field contains the memory start address for IN endpoint Transmit FIFOOn (0 &lt; n &lt;= 15). The power-on reset value of this register is specified as the Largest Rx Data FIFO Depth (parameter OTG_RX_DFIFO_DEPTH). OTG_RX_DFIFO_DEPTH + SUM 0 to n-1 (OTG_DINEP_TXFIFO_DEPTH_n)</p> <p>For example start address of IN endpoint FIFO 1 is OTG_RX_DFIFO_DEPTH + OTG_DINEP_TXFIFO_DEPTH_0. The start address of IN endpoint FIFO 2 is OTG_RX_DFIFO_DEPTH + OTG_DINEP_TXFIFO_DEPTH_0 + OTG_DINEP_TXFIFO_DEPTH_1. If Enable Dynamic FIFO Sizing? was deselected (parameter OTG_DFIFO_DYNAMIC = 0), these flops are optimized, and reads return the power-on value. If Enable Dynamic FIFO Sizing was selected (parameter OTG_DFIFO_DYNAMIC = 1), and you have programmed a new value for RxFIFO depth, you can write that value in this field. Programmed values must not exceed the power-on value set.</p> |

**USBOTG\_HCFG**

Address: Operational Base + offset (0x0400)

Host Configuration Register

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 26         | RW          | 0x0                | <p>PerSchedEna<br/>Enable Periodic Scheduling<br/>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 HCFG.PerSchedStat. The setting of 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.</p> |
| 25:24      | RW          | 0x0                | <p>FrListEn<br/>Frame List Entries<br/>The value in the register specifies the number of entries in the Frame list. This field is valid only in Scatter/Gather DMA mode.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 23         | RW          | 0x0                | <p>DescDMA<br/>Enable Scatter/gather DMA in Host mode<br/>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:<br/>GAHBCFG.DMAEn=0, HCFG.DescDMA=0 =&gt; Slave mode<br/>GAHBCFG.DMAEn=0, HCFG.DescDMA=1 =&gt; Invalid<br/>GAHBCFG.DMAEn=1, HCFG.DescDMA=0 =&gt; Buffered DMA mode<br/>GAHBCFG.DMAEn=1, HCFG.DescDMA=1 =&gt; Scatter/Gather DMA mode<br/>In non-Scatter/Gather DMA mode, this bit is reserved.</p>                                                                              |
| 22:16      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 15:8       | RW          | 0x00               | <p>ResValid<br/>Resume Validation Period<br/>This field is effective only when HCFG.Ena32KHzS is set. It controls the 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.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 7          | RW          | 0x0                | <p>Ena32KHzS<br/>Enable 32-KHz Suspend Mode<br/>This bit can only be set if the 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. 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.</p>                                                                                                                                                                                                                                                                                                             |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6:3        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 2          | RW          | 0x0                | <p>FSLSSupp<br/>FS- and LS-Only Support<br/>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.</p> <p>1'b0: HS/FS/LS, based on the maximum speed supported by the connected device<br/>1'b1: FS/LS-only, even if the connected device can support HS</p> |
| 1:0        | RW          | 0x0                | <p>FSLSPclkSel<br/>FS/LS PHY Clock Select<br/>2'b00: PHY clock is running at 30/60 MHz<br/>2'b01: PHY clock is running at 48 MHz<br/>Others: Reserved</p>                                                                                                                                                                                                                                                                                                           |

**USBOTG\_HFIR**

Address: Operational Base + offset (0x0404)

Host Frame Interval Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 15:0       | RW          | 0x0000             | <p>FrInt<br/>Frame Interval<br/>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 60MHz. 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 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.</p> <p>125 us * (PHY clock frequency for HS)<br/>1 ms * (PHY clock frequency for FS/LS)</p> |

**USBOTG\_HFNUM**

Address: Operational Base + offset (0x0408)

## Host Frame Number/Frame Time Remaining Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | FrRem<br>Frame Time Remaining<br>Indicates the amount of time remaining in the current microframe (HS) or frame (FS/LS), in terms of PHY clocks. This field decrement on each PHY clock. When it reaches zero, this field is reloaded with the value in the Frame Interval register and a new SOF is transmitted on the USB. |
| 15:0       | RO          | 0xfffff            | FrNum<br>Frame Number<br>This field increment when a new SOF is transmitted on the USB, and is reset to 0 when 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.                                      |

**USBOTG\_HPTXSTS**

Address: Operational Base + offset (0x0410)

Host Periodic Transmit FIFO/Queue Status Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24      | RO          | 0x00               | PTxQTop<br>Top of the Periodic Transmit Request Queue<br>This indicates the entry in the Periodic Tx Request Queue that is currently being processes by the MAC. This register is used for debugging.<br>Bit [31]: Odd/Even (micro)frame<br>1'b0: send in even (micro)frame<br>1'b1: send in odd (micro)frame<br>Bits [30:27]: Channel/endpoint number<br>Bits [26:25]: Type<br>2'b00: IN/OUT<br>2'b01: Zero-length packet<br>2'b10: CSPLIT<br>2'b11: Disable channel command<br>Bit [24]: Terminate (last entry for the selected channel/endpoint) |
| 23:16      | RO          | 0x00               | PTxQSpAvail<br>Periodic Transmit Request Queue Space Available<br>Indicates the number of free locations available to be written in the Periodic Transmit Request Queue. This queue holds both IN and OUT requests.<br>8'h0: Periodic Transmit Request Queue is full<br>8'h1: 1 location available<br>8'h2: 2 locations available<br>n: n locations available (0 <=n <= 16)<br>Others: Reserved                                                                                                                                                     |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0       | RW          | 0x0000             | PTxFSpAvail<br>Periodic Transmit Data FIFO Space Available<br>Indicates the number of free locations available to be written to in the Periodic TxFIFO. Values are in terms of 32-bit words<br>16'h0: Periodic TxFIFO is full<br>16'h1: 1 word available<br>16'h2: 2 words available<br>16'hn: n words available (where 0 . n . 32,768)<br>16'h8000: 32,768 words available<br>Others: Reserved |

**USBOTG\_HAIN**

Address: Operational Base + offset (0x0414)

Host All Channels Interrupt Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                            |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0                | reserved                                                                                      |
| 15:0       | RO          | 0x0000             | HAIN<br>Channel Interrupts<br>One bit per channel: Bit 0 for Channel 0, bit 15 for Channel 15 |

**USBOTG\_HINTMSK**

Address: Operational Base + offset (0x0418)

Host All Channels Interrupt Mask Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0                | reserved                                                                                             |
| 15:0       | RW          | 0x0000             | HINTMSk<br>Channel Interrupt Mask<br>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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:19      | RO          | 0x0                | reserved                                                                                                                                                          |
| 18:17      | RO          | 0x0                | PrtSpd<br>Port Speed<br>Indicates the speed of the device attached to this port.<br>2'b00: High speed<br>2'b01: Full speed<br>2'b10: Low speed<br>2'b11: Reserved |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16:13      | RW          | 0x0                | <p>PrtTstCtl<br/>Port Test Control<br/>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.</p> <p>4'b0000: Test mode disabled<br/>4'b0001: Test_J mode<br/>4'b0010: Test_K mode<br/>4'b0011: Test_SE0_NAK mode<br/>4'b0100: Test_Packet mode<br/>4'b0101: Test_Force_Enable<br/>Others: Reserved</p>                                                                                                                                                                                                                                                                                                                          |
| 12         | R/W SC      | 0x0                | <p>PrtPwr<br/>Port Power<br/>The application uses this field to control power to this port (write 1'b1 to set to 1'b1 and write 1'b0 to set to 1'b0), and the core can clear this bit on an over current condition.</p> <p>1'b0: Power off<br/>1'b1: Power on</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 11:10      | RO          | 0x0                | <p>PrtLnsts<br/>Port Line Status<br/>Indicates the current logic level USB data lines</p> <p>Bit [10]: Logic level of D+<br/>Bit [11]: Logic level of D</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 9          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 8          | RW          | 0x0                | <p>PrtRst<br/>Port Reset<br/>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.</p> <p>1'b0: Port not in reset<br/>1'b1: Port in reset</p> <p>To start a reset on the port, the application 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.</p> <p>High speed: 50 ms<br/>Full speed/Low speed: 10 ms</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7          | R/W SC      | 0x0                | <p>PrtSusp<br/>Port Suspend<br/>The application sets this bit to put this port in Suspend mode.<br/>The core only stops sending SOFs when this is set. To stop the PHY clock, the application must set the Port Clock Stop bit, which asserts suspend input pin of the PHY.</p> <p>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).</p> <p>1'b0: Port not in Suspend mode<br/>1'b1: Port in Suspend mode</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 6          | R/W SC      | 0x0                | <p>PrtRes<br/>Port Resume<br/>The application sets this bit to drive resume signaling on the port.<br/>The core continues to drive the resume signal until the application clears this bit.</p> <p>If the core detects a USB remote wakeup sequence, as indicated by the Port Resume/Remote Wakeup Detected Interrupt bit of the Core Interrupt register (GINTSTS.WkUpInt), the core starts driving resume signaling without application intervention and clears this bit when it detects a disconnect condition. The read value of this bit indicates whether the core is currently driving resume signaling.</p> <p>1'b0: No resume driven<br/>1'b1: Resume driven<br/>When LPM is enabled and the core is in the L1 (Sleep) state, setting this bit results in the following behavior:<br/>The core continues to drive the resume signal until a pre-determined time specified in the GLPMCFG.HIRD_Thres[3:0] field.<br/>If the core detects a USB remote wakeup sequence, as indicated by the Port L1 Resume/Remote L1 Wakeup Detected Interrupt bit of the Core Interrupt register (GINTSTS.L1WkUpInt), the core starts driving resume signaling without application intervention and clears this bit at the end of the resume. The read value of this bit indicates whether the core is currently driving resume signaling.</p> <p>1'b0: No resume driven<br/>1'b1: Resume driven</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5          | W1C         | 0x0                | PrtOvrCurrChng<br>Port Overcurrent Change<br>The core sets this bit when the status of the Port Over-current Active bit (bit 4) in this register changes.                                                                                                                                                                                                                                                      |
| 4          | RO          | 0x0                | PrtOvrCurrAct<br>Port Overcurrent Active<br>Indicates the overcurrent condition of the port.<br>1'b0: No overcurrent condition<br>1'b1: Overcurrent condition                                                                                                                                                                                                                                                  |
| 3          | W1C         | 0x0                | PrtEnChng<br>Port Enable/Disable Change<br>The core sets this bit when the status of the Port_Enable bit[2] of this register changes.                                                                                                                                                                                                                                                                          |
| 2          | W1C         | 0x0                | PrtEna<br>Port Enable<br>A port is enabled only by the core after a reset sequence, and is disabled by an over-current condition, a disconnect condition, or by the application clearing this bit. The 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.<br>1'b0: Port disabled<br>1'b1: Port enabled |
| 1          | W1C         | 0x0                | PrtConnDet<br>Port Connect Detected<br>The core sets this bit when a device connection is detected to trigger an interrupt to the application using the Host Port Interrupt bit of the Core Interrupt register (GINTSTS.PrtInt). The application must write a 1 to this bit to clear the interrupt.                                                                                                            |
| 0          | RO          | 0x0                | PrtConnSts<br>Port Connect Status<br>0: No device is attached to the port.<br>1: A device is attached to the port.                                                                                                                                                                                                                                                                                             |

**USBOTG\_HCCCHARn**

Address: Operational Base + offset (0x0500)

Host Channel-n Characteristics Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | R/W<br>SC   | 0x0                | <p>ChEna<br/>Channel Enable<br/>When Scatter/Gather mode is enabled<br/>1'b0: Indicates that the descriptor structure is not yet ready.<br/>1'b1: Indicates that the descriptor structure and data buffer with data is setup and this channel can access the descriptor.<br/>When Scatter/Gather mode is disabled, This field is set by the application and cleared by the OTG host.<br/>1'b0: Channel disabled<br/>1'b1: Channel enabled</p>  |
| 30         | R/W<br>SC   | 0x0                | <p>ChDis<br/>Channel Disable<br/>The application sets this bit to stop transmitting/receiving data on a channel, even before the transfer for that channel is complete.<br/>The application must wait for the Channel Disabled interrupt before treating the channel as disabled.</p>                                                                                                                                                          |
| 29         | RW          | 0x0                | <p>OddFrm<br/>Odd Frame<br/>This field is set (reset) by the application to indicate that the OTG host must perform a transfer in an odd (micro) frame. This field is applicable for only periodic (isochronous and interrupt) transactions.<br/>1'b0: Even (micro)frame<br/>1'b1: Odd (micro)frame<br/>This field is not applicable for Scatter/Gather DMA mode and need not be programmed by the application and is ignored by the core.</p> |
| 28:22      | RW          | 0x00               | <p>DevAddr<br/>Device Address<br/>This field selects the specific device serving as the data source or sink.</p>                                                                                                                                                                                                                                                                                                                               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 21:20      | RW          | 0x0                | <p>MC_EC<br/>Multi Count (MC) / Error Count (EC)</p> <p>When the Split Enable bit of the Host Channel-n Split Control register (HCSPLTn.SpltnEna) 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.</p> <p>2'b00: Reserved This field yields undefined results.<br/>2'b01: 1 transaction<br/>2'b10: 2 transactions to be issued for this endpoint per micro-frame<br/>2'b11: 3 transactions to be issued for this endpoint per micro-frame</p> <p>When HCSPLTn.SpltnEna 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.</p> |
| 19:18      | RW          | 0x0                | <p>EPType<br/>Endpoint Type</p> <p>Indicates the transfer type selected.</p> <p>2'b00: Control<br/>2'b01: Isochronous<br/>2'b10: Bulk<br/>2'b11: Interrupt</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 17         | RW          | 0x0                | <p>LSpdDev<br/>Low-Speed Device</p> <p>This field is set by the application to indicate that this channel is communicating to a low-speed device.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 16         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 15         | RW          | 0x0                | <p>EPDir<br/>Endpoint Direction</p> <p>Indicates whether the transaction is IN or OUT.</p> <p>1'b0: OUT<br/>1'b1: IN</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 14:11      | RW          | 0x0                | <p>EPNum<br/>Endpoint Number</p> <p>Indicates the endpoint number on the device serving as the data source or sink.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 10:0       | RW          | 0x000              | <p>MPS<br/>Maximum Packet Size</p> <p>Indicates the maximum packet size of the associated endpoint.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

**USBOTG\_HCSPLTn**

Address: Operational Base + offset (0x0504)

Host Channel-n Split Control Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RW          | 0x0                | <p>SplEna<br/>Split Enable<br/>The application sets this field to indicate that this channel is enabled to perform split transactions.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 30:17      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 16         | RW          | 0x0                | <p>CompSplt<br/>Do Complete Split<br/>The application sets this field to request the OTG host to perform a complete split transaction.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 15:14      | RW          | 0x0                | <p>XactPos<br/>Transaction Position<br/>This field is used to determine whether to send all, first, middle, or last payloads with each OUT transaction.<br/>2'b11: All. This is the entire data payload is of this transaction (which is less than or equal to 188 bytes).<br/>2'b10: Begin. This is the first data payload of this transaction (which is larger than 188 bytes).<br/>2'b00: Mid. This is the middle payload of this transaction (which is larger than 188bytes).<br/>2'b01: End. This is the last payload of this transaction (which is larger than 188 bytes).</p> |
| 13:7       | RW          | 0x00               | <p>HubAddr<br/>Hub Address<br/>This field holds the device address of the transaction translator's hub.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 6:1        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 0          | RW          | 0x0                | <p>PrtAddr<br/>Port Address<br/>This field is the port number of the recipient transaction translator.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

**USBOTG\_HCINTn**

Address: Operational Base + offset (0x0508)

Host Channel-n Interrupt Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                  |
| 13         | W1C         | 0x0                | <p>DESC_LST_ROLLIntr<br/>Descriptor rollover interrupt<br/>This bit is valid only when Scatter/Gather DMA 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.</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12         | W1C         | 0x0                | XCS_XACT_ERR<br>Excessive Transaction Error<br>This bit is valid only when Scatter/Gather DMA mode is enabled.<br>The core sets this bit when 3 consecutive transaction errors occurred on the USB bus. XCS_XACT_ERR will not be generated for Isochronous channels. For non-Scatter/Gather DMA mode, this bit is reserved.           |
| 11         | W1C         | 0x0                | BNAIntr<br>BNA (Buffer Not Available) Interrupt<br>This bit is valid only when Scatter/Gather DMA mode is enabled.<br>The core generates this 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         | 0x0                | DataTglErr<br>Data Toggle Error<br>In Scatter/Gather DMA mode, the interrupt due to this bit is masked in the core.                                                                                                                                                                                                                   |
| 9          | W1C         | 0x0                | FrmOvrun<br>Frame Overrun<br>In Scatter/Gather DMA mode, the interrupt due to this bit is masked in the core                                                                                                                                                                                                                          |
| 8          | W1C         | 0x0                | BblErr<br>Babble Error<br>In Scatter/Gather DMA mode, the interrupt due to this bit is masked in the core.                                                                                                                                                                                                                            |
| 7          | W1C         | 0x0                | XactErr<br>Transaction Error<br>Indicates one of the following errors occurred on the USB: CRC check failure,<br>Timeout, Bit stuff error, False EOP. In Scatter/Gather DMA mode, the interrupt due to this bit is masked in the core.                                                                                                |
| 6          | WO          | 0x0                | NYET<br>NYET Response Received Interrupt<br>In Scatter/Gather DMA mode, the interrupt due to this bit is masked in the core.                                                                                                                                                                                                          |
| 5          | W1C         | 0x0                | ACK<br>ACK Response Received/Transmitted Interrupt<br>In Scatter/Gather DMA mode, the interrupt due to this bit is masked in the core.                                                                                                                                                                                                |
| 4          | W1C         | 0x0                | NAK<br>NAK Response Received Interrupt<br>In Scatter/Gather DMA mode, the interrupt due to this bit is masked in the core.                                                                                                                                                                                                            |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3          | W1C         | 0x0                | STALL<br>STALL Response Received Interrupt<br>In Scatter/Gather DMA mode, the interrupt due to this bit is masked in the core.                                                                                                                                                                                                                                                                                                                                                                                     |
| 2          | W1C         | 0x0                | AHBErr<br>AHB Error<br>This is generated only in DMA mode when there is an AHB error during AHB read/write. The application can read the corresponding channel's DMA address register to get the error address.                                                                                                                                                                                                                                                                                                    |
| 1          | W1C         | 0x0                | ChHltd<br>Channel Halted<br>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 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) |
| 0          | W1C         | 0x0                | XferCompl<br>Transfer Completed<br>For Scatter/Gather DMA mode, it indicates that current descriptor processing got 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)

Host Channel-n Interrupt Mask Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:14      | RO          | 0x0                | reserved                                                                                                                                                                                        |
| 13         | RW          | 0x0                | DESC_LST_ROLLIntrMsk<br>Descriptor rollover interrupt Mask register<br>This bit is valid only when Scatter/Gather DMA mode is enabled.<br>In non-Scatter/Gather DMA mode, this bit is reserved. |
| 12         | RO          | 0x0                | reserved                                                                                                                                                                                        |
| 11         | RW          | 0x0                | BNAIntrMsk<br>BNA (Buffer Not Available) Interrupt mask register<br>This bit is valid only when Scatter/Gather DMA mode is enabled.<br>In non-Scatter/Gather DMA mode, this bit is reserved.    |
| 10         | RW          | 0x0                | DataTglErrMsk<br>Data Toggle Error Mask<br>This bit is not applicable in Scatter/Gather DMA mode.                                                                                               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9          | RW          | 0x0                | FrmOvrnMsk<br>Frame Overrun Mask<br>This bit is not applicable in Scatter/Gather DMA mode.                                                                          |
| 8          | RW          | 0x0                | BblErrMsk<br>Babble Error Mask<br>This bit is not applicable in Scatter/Gather DMA mode.                                                                            |
| 7          | RW          | 0x0                | XactErrMsk<br>Transaction Error Mask<br>This bit is not applicable in Scatter/Gather DMA mode                                                                       |
| 6          | RW          | 0x0                | NyetMsk<br>NYET Response Received Interrupt Mask<br>This bit is not applicable in Scatter/Gather DMA mode.                                                          |
| 5          | RW          | 0x0                | AckMsk<br>ACK Response Received/Transmitted Interrupt Mask<br>This bit is not applicable in Scatter/Gather DMA mode.                                                |
| 4          | RW          | 0x0                | NakMsk<br>NAK Response Received Interrupt Mask<br>This bit is not applicable in Scatter/Gather DMA mode.                                                            |
| 3          | RW          | 0x0                | StallMsk<br>STALL Response Received Interrupt Mask<br>This bit is not applicable in Scatter/Gather DMA mode.                                                        |
| 2          | RW          | 0x0                | AHBErrMsk<br>AHB Error Mask<br>Note: This bit is only accessible when OTG_ARCHITECTURE = 2                                                                          |
| 1          | RW          | 0x0                | ChHltdMsk<br>Channel Halted Mask                                                                                                                                    |
| 0          | RW          | 0x0                | XferComplMsk<br>Transfer Completed Mask<br>This bit is valid only when Scatter/Gather DMA mode is enabled.<br>In non-Scatter/Gather DMA mode, this bit is reserved. |

**USBOTG\_HCTSIZn**

Address: Operational Base + offset (0x0510)

Host Channel-n Transfer Size Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RW          | 0x0                | DoPng<br>Do Ping<br>This bit is used only for OUT transfers. Setting this field to 1 directs the host to do PING protocol. Note: Do not set this bit for IN transfers. If this bit is set for IN transfers it disables the channel. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 30:29      | RW          | 0x0                | <p>Pid<br/>PID</p> <p>The application programs this field with the type of PID to use for the initial transaction. The host maintains this field for the rest of the transfer.</p> <p>2'b00: DATA0<br/>2'b01: DATA2<br/>2'b10: DATA1<br/>2'b11: MDATA (non-control)/SETUP (control)</p>                                                                                                                                                                                                        |
| 28:19      | RW          | 0x000              | <p>PktCnt<br/>Packet Count</p> <p>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).</p>                            |
| 18:0       | RW          | 0x00000            | <p>XferSize<br/>Transfer Size</p> <p>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).</p> |

**USBOTG\_HCDMAN**

Address: Operational Base + offset (0x0514)

Host Channel-n DMA Address Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | <p>DMAAddr<br/>DMA Address</p> <p>This field holds the start address in the 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.</p> |

**USBOTG\_HCDMABn**

Address: Operational Base + offset (0x051c)

Host Channel-n DMA Buffer Address Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | HCDMABn<br>Holds the current buffer address<br>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\_DCFG**

Address: Operational Base + offset (0x0800)

Device Configuration Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:26      | RW          | 0x02               | ResValid<br>Resume Validation Period<br>This field controls the period when the core resumes from a suspended. When this bit is set, the core counts for the Resume Valid number of clock cycles to detect a valid resume. This field is effective only when DCFG.Ena32KHzSusp is set.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 25:24      | RW          | 0x0                | PerSchIntvl<br>Periodic Scheduling Interval<br>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.<br>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 non-periodic endpoints, ignoring this field. After the specified time within a (micro) frame, the DMA switches to fetching for non-periodic endpoints.<br>2'b00: 25% of (micro) frame.<br>2'b01: 50% of (micro) frame.<br>2'b10: 75% of (micro) frame.<br>2'b11: Reserved. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23         | RW          | 0x0                | <p>DescDMA</p> <p>Enable Scatter/Gather DMA in Device mode</p> <p>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:</p> <ul style="list-style-type: none"> <li>GAHBCFG.DMAEn=0, DCFG.DescDMA=0 =&gt; Slave mode</li> <li>GAHBCFG.DMAEn=0, DCFG.DescDMA=1 =&gt; Invalid</li> <li>GAHBCFG.DMAEn=1, DCFG.DescDMA=0 =&gt; Buffered DMA mode</li> <li>GAHBCFG.DMAEn=1, DCFG.DescDMA=1 =&gt; Scatter/Gather DMA mode</li> </ul> |
| 22:18      | RW          | 0x08               | <p>EPMisCnt</p> <p>IN Endpoint Mismatch Count</p> <p>This field is valid only in shared FIFO operation. The application programs this field with a count that determines when the core generates an Endpoint Mismatch interrupt (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.</p>                                                                                                                                                                                               |
| 17:13      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 12:11      | RW          | 0x0                | <p>PerFrInt</p> <p>Periodic Frame Interval</p> <p>Indicates the time within a (micro) frame at which the application must be notified using the End Of Periodic Frame Interrupt. This can be used to determine if all the isochronous traffic for that (micro) frame is complete.</p> <p>2'b00: 80% of the (micro) frame interval<br/>     2'b01: 85%<br/>     2'b10: 90%<br/>     2'b11: 95%</p>                                                                                                                                                                                                                                                                          |
| 10:4       | RW          | 0x00               | <p>DevAddr</p> <p>Device Address</p> <p>The application must program this field after every SetAddress control command.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 3          | RW          | 0x0                | <p>Ena32KHzS</p> <p>Enable 32-KHz Suspend Mode</p> <p>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. 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.</p>                                                                                                                                                                                                                                         |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2          | RW          | 0x0                | <p>NZStsOUTHShk<br/>Non-Zero-Length Status OUT Handshake<br/>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.</p> <p>1'b1: Send a STALL handshake on a nonzero-length status OUT transaction and do not send the received OUT packet to the application.</p> <p>1'b0: Send the received OUT packet to the application (zero-length or non-zero length) and send a handshake based on the NAK and STALL bits for the endpoint in the Device Endpoint Control register.</p> |
| 1:0        | RW          | 0x0                | <p>DevSpd<br/>Device Speed<br/>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 speed of the USB host to which the core is connected.</p> <p>2'b00: High speed (USB 2.0 PHY clock is 30 MHz or 60 MHz)<br/>2'b01: Full speed (USB 2.0 PHY clock is 30 MHz or 60 MHz)<br/>2'b10: Reserved<br/>2'b11: Full speed (USB 1.1 transceiver clock is 48 MHz)</p>                                                            |

**USBOTG\_DCTL**

Address: Operational Base + offset (0x0804)

Device Control Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------|
| 31:17      | RO          | 0x0                | reserved                                                                                                                               |
| 16         | RW          | 0x0                | <p>NakOnBble<br/>Set NAK automatically on babble<br/>The core sets NAK automatically for the endpoint on which babble is received.</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15         | RW          | 0x0                | <p>IgnrFrmNum<br/>Ignore frame number for isochronous endpoints in case of Scatter<br/>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 high speed, high-bandwidth transfers. When this bit is enabled, there must be only one packet per descriptor.</p> <p>0: The core transmits the packets only in the frame number in which they are intended to be transmitted.<br/>1: The core ignores the frame number, sending packets immediately as the packets are ready.</p> <p>Scatter/Gather:<br/>In Scatter/Gather DMA mode, when this bit is enabled, the packets are not flushed when an ISOC IN token is received for an elapsed frame.<br/>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 multiple (micro) frames.<br/>0: Periodic transfer interrupt feature is disabled; the application must program transfers for periodic endpoints every (micro)frame<br/>1: Periodic transfer interrupt feature is enabled; the application can program transfers for multiple (micro) frames for periodic endpoints.<br/>In non-Scatter/Gather DMA mode, the application receives transfer complete interrupt after transfers for multiple (micro) frames are completed.</p> |
| 14:13      | RW          | 0x1                | <p>GMC<br/>Global Multi Count<br/>GMC must be programmed only once after initialization.<br/>Applicable only for Scatter/Gather DMA mode. This indicates the number of packets to be serviced for that end point before moving to the next end point. It is only for non-periodic endpoints.<br/>2'b00: Invalid.<br/>2'b01: 1 packet.<br/>2'b10: 2 packets.<br/>2'b11: 3 packets.<br/>When Scatter/Gather DMA mode is disabled, this field is reserved, and reads 2'b00.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 12         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11         | RW          | 0x0                | PWROnPrgDone<br>Power-On Programming Done<br>The application uses this bit to indicate that register programming is completed after a wake-up from Power Down mode.                                                                                                                                                                                                                                                                                                                     |
| 10         | WO          | 0x0                | CGOUTNak<br>Clear Global OUT NAK<br>A write to this field clears the Global OUT NAK.                                                                                                                                                                                                                                                                                                                                                                                                    |
| 9          | WO          | 0x0                | SGOUTNak<br>Set Global OUT NAK<br>A write to this field sets the Global OUT NAK. The application uses this bit to send a NAK handshake on all OUT endpoints. The application must set this bit only after making sure that the Global OUT NAK Effective bit in the Core Interrupt Register (GINTSTS.GOUTNakEff) is cleared.                                                                                                                                                             |
| 8          | WO          | 0x0                | CGNPInNak<br>Clear Global Non-periodic IN NAK<br>A write to this field clears the Global Non-periodic IN NAK.                                                                                                                                                                                                                                                                                                                                                                           |
| 7          | WO          | 0x0                | SGNPInNak<br>Set Global Non-periodic IN NAK<br>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 endpoints. The core can also set this bit when a 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. |
| 6:4        | RW          | 0x0                | TstCtl<br>Test Control<br>3'b000: Test mode disabled<br>3'b001: Test_J mode<br>3'b010: Test_K mode<br>3'b011: Test_SE0_NAK mode<br>3'b100: Test_Packet mode<br>3'b101: Test_Force_Enable<br>Others: Reserved                                                                                                                                                                                                                                                                            |
| 3          | RO          | 0x0                | GOUTNakSts<br>Global OUT NAK Status<br>1'b0: A handshake is sent based on the FIFO Status and the NAK and STALL bit settings.<br>1'b1: No data is written to the RxFIFO, irrespective of space availability. Sends a NAK handshake on all packets, except on SETUP transactions. All isochronous OUT packets are dropped                                                                                                                                                                |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2          | RO          | 0x0                | <p>GNPINNaksts<br/>Global Non-periodic IN NAK Status<br/>1'b0: A handshake is sent out based on the data availability in the transmit FIFO.<br/>1'b1: A NAK handshake is sent out on all non-periodic IN endpoints, irrespective of the data availability in the transmit FIFO.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 1          | RW          | 0x0                | <p>SftDiscon<br/>Soft Disconnect<br/>The application uses this bit to signal the DWC_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.<br/>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.<br/>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.</p>                                                                             |
| 0          | RW          | 0x0                | <p>RmtWkUpSig<br/>Remote Wakeup Signaling<br/>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 1ms 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.</p> |

**USBOTG\_DSTS**

Address: Operational Base + offset (0x0808)

Device Status Register

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 21:8       | RW          | 0x0000             | SOFFN<br>Frame or Micro-frame Number of the Received SOF<br>When the core is operating at high speed, this field contains a micro-frame number. When the core is operating at full or low speed, this field contains a frame number.                                                                                                                                                                                                                                                                                  |
| 7:4        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 3          | RW          | 0x0                | ErrticErr<br>Erratic Error<br>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 2ms, due to PHY error) seen on the UTMI+. Due to erratic errors, the DWC_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. |
| 2:1        | RW          | 0x0                | EnumSpd<br>Enumerated Speed<br>Indicates the speed at which the DWC_otg core has come up after speed detection through a chirp sequence.<br>2'b00: High speed (PHY clock is running at 30 or 60 MHz)<br>2'b01: Full speed (PHY clock is running at 30 or 60 MHz)<br>2'b10: Low speed (PHY clock is running at 48 MHz, internal phy_clk at 6 MHz)<br>2'b11: Full speed (PHY clock is running at 48 MHz)<br>Low speed is not supported for devices using a UTMI+ PHY.                                                   |
| 0          | RW          | 0x0                | SuspSts<br>Suspend Status<br>In Device mode, this bit is set as long as a Suspend condition is detected on the USB. The core enters the Suspended state when there is no activity on the utmi_linstate signal for an extended period of time. The core comes out of the suspend: When there is any activity on the utmi_linstate 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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>           |
|------------|-------------|--------------------|------------------------------|
| 31:14      | RO          | 0x0                | reserved                     |
| 13         | RW          | 0x0                | NAKMsk<br>NAK interrupt Mask |
| 12:10      | RO          | 0x0                | reserved                     |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                         |
|------------|-------------|--------------------|------------------------------------------------------------|
| 9          | RW          | 0x0                | BNAInIntrMsk<br>BNA Interrupt Mask                         |
| 8          | RW          | 0x0                | TxfifoUndrnMsk<br>Fifo Underrun Mask                       |
| 7          | RO          | 0x0                | reserved                                                   |
| 6          | RW          | 0x0                | INEPNakEffMsk<br>IN Endpoint NAK Effective Mask            |
| 5          | RW          | 0x0                | INTknEPMisMsk<br>IN Token received with EP Mismatch Mask   |
| 4          | RW          | 0x0                | INTknTXFEMpMsk<br>IN Token Received When TxFIFO Empty Mask |
| 3          | RW          | 0x0                | TimeOUTMsk<br>Timeout Condition Mask                       |
| 2          | RW          | 0x0                | AHBErrMsk<br>AHB Error Mask                                |
| 1          | RW          | 0x0                | EPDisbldMsk<br>Endpoint Disabled Interrupt Mask            |
| 0          | RW          | 0x0                | XferComplMsk<br>Transfer Completed Interrupt Mask          |

**USBOTG\_DOEPMSK**

Address: Operational Base + offset (0x0814)

Device OUT Endpoint common interrupt mask register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------|
| 31:15      | RO          | 0x0                | reserved                                                                                                   |
| 14         | RW          | 0x0                | NYETMsk<br>NYET Interrupt Mask                                                                             |
| 13         | RW          | 0x0                | NAKMsk<br>NAK Interrupt Mask                                                                               |
| 12         | RW          | 0x0                | BbleErrMsk<br>Babble Interrupt Mask                                                                        |
| 11:10      | RO          | 0x0                | reserved                                                                                                   |
| 9          | RW          | 0x0                | BnaOutIntrMsk<br>BNA interrupt Mask                                                                        |
| 8          | RW          | 0x0                | OutPktErrMsk<br>OUT Packet Error Mask                                                                      |
| 7          | RO          | 0x0                | reserved                                                                                                   |
| 6          | RW          | 0x0                | Back2BackSETup<br>Back-to-Back SETUP Packets Received Mask<br>Applies to control OUT endpoints only.       |
| 5          | RO          | 0x0                | reserved                                                                                                   |
| 4          | RW          | 0x0                | OUTTknEPdisMsk<br>OUT Token Received when Endpoint Disabled Mask<br>Applies to control OUT endpoints only. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------|
| 3          | RW          | 0x0                | SetUPMsk<br>SETUP Phase Done Mask<br>Applies to control endpoints only. |
| 2          | RW          | 0x0                | AHBErrMsk<br>AHB Error                                                  |
| 1          | RW          | 0x0                | EPDisbldMsk<br>Endpoint Disabled Interrupt Mask                         |
| 0          | RW          | 0x0                | XferComplMsk<br>Transfer Completed Interrupt Mask                       |

**USBOTG\_DAINT**

Address: Operational Base + offset (0x0818)

Device All Endpoints interrupt register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | OutEPInt<br>OUT Endpoint Interrupt Bits<br>One bit per OUT endpoint: Bit 16 for OUT endpoint 0, bit 31 for OUT endpoint 15 |
| 15:0       | RO          | 0x0000             | InEpInt<br>IN Endpoint Interrupt Bits<br>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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                        |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | OutEpMsk<br>OUT EP Interrupt Mask Bits<br>One per OUT Endpoint: Bit 16 for OUT EP 0, bit 31 for OUT EP 15 |
| 15:0       | RW          | 0x0000             | InEpMsk<br>IN EP Interrupt Mask Bits<br>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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0000000          | EPTkn<br>Endpoint Token<br>Four bits per token represent the endpoint number of the token:<br>Bits [31:28]: Endpoint number of Token 5<br>Bits [27:24]: Endpoint number of Token 4<br>.....<br>Bits [15:12]: Endpoint number of Token 1<br>Bits [11:8]: Endpoint number of Token 0 |
| 7          | RO          | 0x0                | WrapBit<br>Wrap Bit<br>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        | RO          | 0x00               | INTknWPtr<br>IN Token Queue Write Pointer                                                                                                                                                                                                                                          |

**USBOTG\_DTKNQR2**

Address: Operational Base + offset (0x0824)

Device IN token sequence learning queue read register2

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | EPTkn<br>Endpoint Token<br>Four bits per token represent the endpoint number of the token:<br>Bits [31:28]: Endpoint number of Token 13<br>Bits [27:24]: Endpoint number of Token 12<br>.....<br>Bits [7:4]: Endpoint number of Token 7<br>Bits [3:0]: Endpoint number of Token 6 |

**USBOTG\_DVBUSDIS**

Address: Operational Base + offset (0x0828)

Device VBUS discharge time register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                    |
| 15:0       | RW          | 0x0b8f             | DVBUSDis<br>Device VBUS Discharge Time<br>Specifies the VBUS discharge time after VBUS pulsing during SRP.<br>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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:12      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                      |
| 11:0       | RW          | 0x000              | DVBUSPulse<br>Device VBUS Pulsing Time<br>Specifies the VBUS pulsing time during SRP. This value equals:<br>VBUS pulsing time in PHY clocks / 1,024. The value you use<br>depends whether the PHY is operating at 30 MHz (16-bit data<br>width) or 60 MHz (8-bit data width). |

**USBOTG\_DTHRCTL**

Address: Operational Base + offset (0x0830)

Device Threshold Control Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                         |
| 27         | RW          | 0x1                | ArbPrkEn<br>Arbiter Parking Enable<br>This bit controls internal DMA arbiter parking for IN endpoints.<br>When threshold is enabled and this bit is set to one, then the<br>arbiter parks on the IN endpoint for which there is a token<br>received on the USB. This is done to avoid getting into under-run<br>conditions. By default the parking is enabled.                                   |
| 26         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                         |
| 25:17      | RW          | 0x008              | RxThrLen<br>Receive Threshold Length<br>This field specifies Receive threshold size in DWORDS. This field<br>also specifies the amount of data received on the USB before the<br>core can start transmitting on the AHB. The threshold length has<br>to be at least eight DWORDS.<br>The recommended value for ThrLen is to be the same as the<br>programmed AHB Burst Length (GAHBCFG.HBstLen). |
| 16         | RW          | 0x0                | RxThrEn<br>Receive Threshold Enable<br>When this bit is set, the core enables threshold in the receive<br>direction.                                                                                                                                                                                                                                                                             |
| 15:13      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                         |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12:11      | RW          | 0x0                | <p>AHBThrRatio<br/>AHB Threshold Ratio<br/>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.</p> <p>2'b00: AHB threshold = MAC threshold<br/>2'b01: AHB threshold = MAC threshold / 2<br/>2'b10: AHB threshold = MAC threshold / 4<br/>2'b11: AHB threshold = MAC threshold / 8</p> |
| 10:2       | RW          | 0x008              | <p>TxThrLen<br/>Transmit Threshold Length<br/>This field specifies Transmit threshold 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 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.</p> <p>This field controls both isochronous and non-isochronous IN endpoint thresholds.<br/>The recommended value for ThrLen is to be the same as the programmed AHB Burst Length (GAHBCFG.HBstLen).</p>                                                                                                                                                                                    |
| 1          | RW          | 0x0                | <p>ISOThrEn<br/>ISO IN Endpoints Threshold Enable<br/>When this bit is set, the core enables threshold for isochronous IN endpoints.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 0          | RW          | 0x0                | <p>NonISOThrEn<br/>Non-ISO IN Endpoints Threshold Enable<br/>When this bit is set, the core enables threshold for Non Isochronous IN endpoints.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

**USBOTG\_DIEPEMPMSK**

Address: Operational Base + offset (0x0834)

Device IN endpoint FIFO empty interrupt mask register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0                | reserved                                                                                                                                                                                                    |
| 15:0       | RW          | 0x0000             | InEpTxfEmpMsk<br>IN EP Tx FIFO Empty Interrupt Mask Bits<br>These bits act as mask bits for DIEPINTn. TxFEmp interrupt One bit per IN Endpoint:<br>Bit 0 for IN endpoint 0<br>...<br>Bit 15 for endpoint 15 |

**USBOTG\_DEACHINT**

Address: Operational Base + offset (0x0838)

Device each endpoint interrupt register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | EchOutEPInt<br>OUT Endpoint Interrupt Bits<br>One bit per OUT endpoint:<br>Bit 16 for OUT endpoint 0<br>...<br>Bit 31 for OUT endpoint 15 |
| 15:0       | RO          | 0x0000             | EchInEpInt<br>IN Endpoint Interrupt Bits<br>One bit per IN Endpoint:<br>Bit 0 for IN endpoint 0<br>...<br>Bit 15 for endpoint 15          |

**USBOTG\_DEACHINTMSK**

Address: Operational Base + offset (0x083c)

Device each endpoint interrupt register mask

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | EchOutEpMsk<br>OUT EP Interrupt Mask Bits<br>One per OUT Endpoint:<br>Bit 16 for IN endpoint 0<br>...<br>Bit 31 for endpoint 15 |
| 15:0       | RW          | 0x0000             | EchInEpMsk<br>IN EP Interrupt Mask Bits<br>One bit per IN Endpoint:<br>Bit 0 for IN endpoint 0<br>...<br>Bit 15 for endpoint 15 |

**USBOTG\_DIEPEACHMSKn**

Address: Operational Base + offset (0x0840)

Device each IN endpoint -n interrupt Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------|
| 31:14      | RO          | 0x0                | reserved                                                        |
| 13         | RW          | 0x0                | NAKMsk<br>NAK interrupt Mask                                    |
| 12:10      | RO          | 0x0                | reserved                                                        |
| 9          | RW          | 0x0                | BNAInIntrMsk<br>BNA interrupt Mask                              |
| 8          | RW          | 0x0                | TxfifoUndrnMsk<br>Fifo Under run Mask                           |
| 7          | RO          | 0x0                | reserved                                                        |
| 6          | RW          | 0x0                | INEPNakEffMsk<br>IN Endpoint NAK Effective Mask                 |
| 5          | RW          | 0x0                | INTknEPMisMsk<br>IN Token received with EP Mismatch Mask        |
| 4          | RW          | 0x0                | INTknTXFEmptyMsk<br>IN Token Received When TxFIFO Empty Mask    |
| 3          | RW          | 0x0                | TimeOUTMsk<br>Timeout Condition Mask(Non-isochronous endpoints) |
| 2          | RW          | 0x0                | AHBErrMsk<br>AHB Error Mask                                     |
| 1          | RW          | 0x0                | EPDisbldMsk<br>Endpoint Disabled Interrupt Mask                 |
| 0          | RW          | 0x0                | XferComplMsk<br>Transfer Completed Interrupt Mask               |

### **USBOTG\_DOEPEACHMSKn**

Address: Operational Base + offset (0x0880)

Device each out endpoint-n interrupt register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                    |
|------------|-------------|--------------------|---------------------------------------|
| 31:15      | RO          | 0x0                | reserved                              |
| 14         | RW          | 0x0                | NYETMsk<br>NYET interrupt Mask        |
| 13         | RW          | 0x0                | NAKMsk<br>NAK interrupt Mask          |
| 12         | RW          | 0x0                | BbleErrMsk<br>Babble interrupt Mask   |
| 11:10      | RO          | 0x0                | reserved                              |
| 9          | RW          | 0x0                | BnaOutIntrMsk<br>BNA interrupt Mask   |
| 8          | RW          | 0x0                | OutPktErrMsk<br>OUT Packet Error Mask |
| 7          | RO          | 0x0                | reserved                              |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------|
| 6          | RW          | 0x0                | Back2BackSETUp<br>Back-to-Back SETUP Packets Received Mask<br>Applies to control OUT endpoints only.       |
| 5          | RO          | 0x0                | reserved                                                                                                   |
| 4          | RW          | 0x0                | OUTTknEPdisMsk<br>OUT Token Received when Endpoint Disabled Mask<br>Applies to control OUT endpoints only. |
| 3          | RW          | 0x0                | SetUPMsk<br>SETUP Phase Done Mask<br>Applies to control endpoints only.                                    |
| 2          | RW          | 0x0                | AHBErrMsk<br>AHB Error                                                                                     |
| 1          | RW          | 0x0                | EPDisbldMsk<br>Endpoint Disabled Interrupt Mask                                                            |
| 0          | RW          | 0x0                | XferComplMsk<br>Transfer Completed Interrupt Mask                                                          |

**USBOTG\_DIEPCTL0**

Address: Operational Base + offset (0x0900)

Device control IN endpoint 0 control register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | R/W SC      | 0x0                | EPEna<br>Endpoint Enable<br>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.<br>The core clears this bit before setting the following interrupts on this endpoint: Endpoint Disabled; Transfer Completed. |
| 30         | R/W SC      | 0x0                | EPDis<br>Endpoint Disable<br>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                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 27         | WO          | 0x0                | SNAK<br>Set NAK<br>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<br>Clear NAK<br>A write to this bit clears the NAK bit for the endpoint.                                                                                                                                                                                                                                                                                                                                                                         |
| 25:23      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 22         | RW          | 0x0                | TxFNum<br>TxFIFO Number<br>For Shared FIFO operation, this value is always set to 0, indicating that control IN 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.                                                                                                                                                            |
| 21         | R/W SC      | 0x0                | Stall<br>STALL Handshake<br>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.                                                                                                                                                                                    |
| 20         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 19:18      | RO          | 0x0                | EPType<br>Endpoint Type<br>Hardcoded to 00 for control                                                                                                                                                                                                                                                                                                                                                                                                |
| 17         | RO          | 0x0                | NAKSts<br>NAK Status<br>Indicates the following:<br>1'b0: The core is transmitting non-NAK handshakes based on the FIFO status<br>1'b1: The core is transmitting NAK handshakes on this endpoint. When this bit is set, either by the application or core, the core stops transmitting data, even if there is data available in the TxFIFO. Irrespective of this bit's setting, the core always responds to SETUP data packets with an ACK handshake. |
| 16         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 15         | RO          | 0x1                | USBActEP<br>USB Active Endpoint<br>This bit is always set to 1, indicating that control endpoint 0 is always active in all configurations and interfaces.                                                                                                                                                                                                                                                                                             |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14:11      | RW          | 0x0                | <p>NextEp<br/>Next Endpoint</p> <p>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.</p> <p>Note: This field is valid only for Shared FIFO operations.</p> |
| 10:2       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                         |
| 1:0        | RW          | 0x0                | <p>MPS<br/>Maximum Packet Size</p> <p>Applies to IN and OUT endpoints. The application must program this field with the maximum packet size for the current logical endpoint.</p> <p>2'b00: 64 bytes<br/>2'b01: 32 bytes<br/>2'b10: 16 bytes<br/>2'b11: 8 bytes</p>                                                                                                              |

**USBOTG\_DIEPINTn**

Address: Operational Base + offset (0x0908)

Device Endpoint-n Interrupt Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:15      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                               |
| 14         | W1C         | 0x0                | <p>NYETIntrpt<br/>NYET interrupt</p> <p>The core generates this interrupt when a NYET response is transmitted for a non-isochronous OUT endpoint.</p>                                                                                                                                                                                  |
| 13         | W1C         | 0x0                | <p>NAKIntrpt<br/>NAK interrupt</p> <p>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.</p>                                               |
| 12         | W1C         | 0x0                | <p>BbleErrIntrpt<br/>BbleErr (Babble Error) interrupt</p> <p>The core generates this interrupt when babble is received for the endpoint.</p>                                                                                                                                                                                           |
| 11         | W1C         | 0x0                | <p>PktDrpSts<br/>Packet Dropped Status</p> <p>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.</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 9          | W1C         | 0x0                | BNAIntr<br>BNA (Buffer Not Available) Interrupt<br>The core generates this interrupt when the 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.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 8          | W1C         | 0x0                | TxfifoUndrn<br>FIFO Underrun<br>Applies to IN endpoints only. The core generates this interrupt when it detects a transmit FIFO under-run condition for this endpoint. Dependency: This interrupt is valid only when both of the following conditions are true: Parameter OTG_ENDED_TX_FIFO==1; Threshold 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_ENDED_TX_FIFO==1; Threshold is enabled.                                                                                                                                                                                       |
| 7          | W1C         | 0x0                | TxFEmp<br>Transmit FIFO Empty<br>This bit is valid only for IN Endpoints. This interrupt is asserted when the Tx FIFO for this endpoint is either half or completely empty. The half or completely empty status is determined by the Tx FIFO Empty Level bit in the Core AHB Configuration register (GAHBCFG.NPTxFEmpLvl)).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 6          | W1C         | 0x0                | INEPNakEff<br>IN Endpoint NAK Effective<br>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 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.<br>This bit indicates that the core has received more than three back-to-back SETUP packets for this particular endpoint. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5          | W1C         | 0x0                | <p>INTknEPMis<br/>IN Token Received with EP Mismatch<br/>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)<br/>This interrupt is valid only for Control OUT 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.</p> |
| 4          | W1C         | 0x0                | <p>INTknTxFEmp<br/>IN Token Received When TxFIFO is Empty<br/>Indicates that an IN token was received when the associated TxFIFO periodic/non-periodic) was empty. This interrupt is asserted on the endpoint for which the IN token was received.<br/>OUT Token Received When Endpoint Disabled (OUTTknEPdis)<br/>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.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 3          | W1C         | 0x0                | <p>TimeOUT<br/>Timeout Condition<br/>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.<br/>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.</p>                                                                                                                                                                                                                                                                                                                        |
| 2          | W1C         | 0x0                | <p>AHBErr<br/>AHB Error<br/>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.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1          | W1C         | 0x0                | EPDisbld<br>Endpoint Disabled Interrupt<br>Applies to IN and OUT endpoints. This bit indicates that the endpoint is disabled per the application's request.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 0          | W1C         | 0x0                | XferCompl<br>Transfer Completed Interrupt<br>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)

Device endpoint n transfer size register

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 30:29      | RW          | 0x0                | <p>MC<br/>Multi Count<br/>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.</p> <p>2'b01: 1 packet<br/>2'b10: 2 packets<br/>2'b11: 3 packets</p> <p>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 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.</p> <p>2'b00: DATA0<br/>2'b01: DATA2<br/>2'b10: DATA1<br/>2'b11: MDATA</p> <p>SETUP Packet Count (SUPCnt).Applies to control OUT Endpoints only.This field specifies the number of back-to-back SETUP data packets the endpoint can receive.</p> <p>2'b01: 1 packet<br/>2'b10: 2 packets<br/>2'b11: 3 packets</p> |
| 28:19      | RW          | 0x000              | <p>PktCnt<br/>Packet Count<br/>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 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 Rx FIFO.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 18:0       | RW          | 0x000000           | XferSize<br>Transfer Size<br>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 configuration (parameter OTG_TRANS_COUNT_WIDTH). The core only interrupts the application after it has exhausted 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 decrements this field every time a packet from the external memory is written to the TxFIFO.OUT Endpoints: The core decrements this field every time a packet is read from the RxFIFO and written to the external memory. |

**USBOTG\_DIEPDMA<sub>n</sub>**

Address: Operational Base + offset (0x0914)

Device endpoint-n DMA Address Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | DMAAddr<br>DMA Address<br>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.<br>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\_DTXFSTS<sub>n</sub>**

Address: Operational Base + offset (0x0918)

Device IN endpoint transmit FIFO status register

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0       | RW          | 0x0000             | <p>INEPTxFSpcAvail<br/>IN Endpoint TxFIFO Space Avail<br/>Indicates the amount of free space available in the Endpoint TxFIFO.Values in terms of 32-bit words.</p> <p>16'h0: Endpoint TxFIFO is full<br/>16'h1: 1 word available<br/>16'h2: 2 words available<br/>16'hn: n words available (where 0 . n . 32,768)<br/>16'h8000: 32,768 words available<br/>Others: Reserved</p> |

**USBOTG\_DIEPDMABn**

Address: Operational Base + offset (0x091c)

Device endpoint-n DMA buffer address register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | <p>DMABufferAddr<br/>DMA Buffer Address<br/>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.</p> |

**USBOTG\_DIEPCTLn**

Address: Operational Base + offset (0x0920)

Device endpoint-n control register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | R/W SC      | 0x0                | <p>EPEna<br/>Endpoint Enable<br/>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.</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 30         | R/W SC      | 0x0                | <p>EPDis<br/>Endpoint Disable</p> <p>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.</p>                                                                                                                                                                                                                                      |
| 29         | WO          | 0x0                | <p>SetD1PID<br/>Set DATA1 PID</p> <p>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 Scatter/Gather DMA mode and 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.</p>                                                                                                                                                                                                           |
| 28         | WO          | 0x0                | <p>SetD0PID<br/>Set DATA0 PID</p> <p>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 (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 received descriptor structure.</p> |
| 27         | WO          | 0x0                | <p>SNAK<br/>Set NAK</p> <p>Applies to IN and OUT endpoints. 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 OUT endpoints on a Transfer Completed interrupt, or after a SETUP is received on the endpoint.</p>                                                                                                                                                                                                                                                                                                                                                                               |
| 26         | WO          | 0x0                | <p>CNAK<br/>Clear NAK</p> <p>Applies to IN and OUT endpoints. A write to this bit clears the NAK bit for the endpoint.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 25:22      | RW          | 0x0                | <p>TxFNum<br/>Tx FIFO Number</p> <p>Shared FIFO Operation: non-periodic endpoints must set this bit to zero. Periodic endpoints must map this to the corresponding Periodic Tx FIFO number. 4'h0: Non-Periodic Tx FIFO; Others: Specified Periodic Tx FIFO 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 using coreConsultant, 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.</p> |
| 21         | RW          | 0x0                | <p>Stall<br/>STALL Handshake</p> <p>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.</p> <p>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.</p>                                                                                                                                                                                                           |
| 20         | RW          | 0x0                | <p>Snp<br/>Snoop Mode</p> <p>Applies to OUT endpoints only. 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.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 19:18      | RW          | 0x0                | <p>EPType<br/>Endpoint Type</p> <p>Applies to IN and OUT endpoints. This is the transfer type supported by this logical endpoint.</p> <p>2'b00: Control<br/>2'b01: Isochronous<br/>2'b10: Bulk<br/>2'b11: Interrupt</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 17         | RO          | 0x0                | <p>NAKSts<br/>NAK Status<br/>Applies to IN and OUT endpoints. Indicates the following:<br/>1'b0: The core is transmitting non-NAK handshakes based on the FIFO status.<br/>1'b1: The core is transmitting NAK handshakes on this endpoint.<br/>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. For non-isochronous IN endpoints: The core stops transmitting any data on an IN endpoint, even if there data is available in the TxFIFO. For isochronous IN endpoints: The core sends out a zero-length data packet, even if there data is available in the TxFIFO. Irrespective of this bit's setting, the core always responds to SETUP data packets with an ACK handshake.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 16         | RO          | 0x0                | <p>DPID<br/>Endpoint Data PID<br/>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.<br/>1'b0: DATA0<br/>1'b1: DATA1<br/>This field is applicable both for Scatter/Gather DMA mode and non-Scatter/Gather DMA mode.Even/Odd (Micro)Frame (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.<br/>1'b0: Even (micro)frame<br/>1'b1: Odd (micro)frame<br/>When Scatter/Gather DMA mode is enabled, this field is reserved. The frame number in which to send data is provided in the transmit descriptor structure. The frame in which data is received is updated in receive descriptor structure.</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15         | R/W<br>SC   | 0x0                | USBActEP<br>USB Active Endpoint<br>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 registers accordingly and set this bit. |
| 14:11      | RW          | 0x0                | NextEp<br>Next Endpoint<br>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          | 0x000              | MPS<br>Maximum Packet Size<br>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\_DOEPCCTL0**

Address: Operational Base + offset (0x0b00)

Device control OUT endpoint 0 control register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | R/W<br>SC   | 0x0                | EPEna<br>Endpoint Enable<br>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.<br>Note: In DMA mode, this bit must be set for the core to transfer SETUP data packets into memory. |
| 30         | WO          | 0x0                | EPDis<br>Endpoint Disable<br>The application cannot disable control OUT endpoint 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 29:28      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 27         | WO          | 0x0                | SNAK<br>Set NAK<br>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         | WO          | 0x0                | CNAK<br>Clear NAK<br>A write to this bit clears the NAK bit for the endpoint.                                                                                                                                                                                                                                                                                                                                                                                                |
| 25:22      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 21         | R/W SC      | 0x0                | Stall<br>STALL Handshake<br>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<br>Snoop Mode<br>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          | 0x0                | EPType<br>Endpoint Type<br>Hardcoded to 2'b00 for control.                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 17         | RO          | 0x0                | NAKsts<br>NAK Status<br>Indicates the following:<br>1'b0: The core is transmitting non-NAK handshakes based on the FIFO status.<br>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.<br>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<br>USB Active Endpoint<br>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                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0        | RO          | 0x0                | MPS<br>Maximum Packet Size<br>The maximum packet size for control OUT endpoint 0 is the same as what is programmed in control IN Endpoint 0.<br>2'b00: 64 bytes<br>2'b01: 32 bytes<br>2'b10: 16 bytes<br>2'b11: 8 bytes |

**USBOTG\_DOEPINTn**

Address: Operational Base + offset (0x0b08)

Device endpoint-n control register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:15      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                   |
| 14         | W1C         | 0x0                | NYETInrpt<br>NYET interrupt<br>The core generates this interrupt when a NYET response is transmitted for a non-isochronous OUT endpoint.                                                                                                                                                                                   |
| 13         | W1C         | 0x0                | NAKInrpt<br>NAK interrupt<br>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         | 0x0                | BbleErrInrpt<br>BbleErr (Babble Error) interrupt<br>The core generates this interrupt when babble is received for the endpoint.                                                                                                                                                                                            |
| 11         | W1C         | 0x0                | PktDrpSts<br>Packet Dropped Status<br>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                                                                                                                                                                                                                                                                                                                   |
| 9          | W1C         | 0x0                | BNAInrtrpt<br>BNA (Buffer Not Available) Interrupt<br>The core generates this interrupt when the 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.                                                      |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8          | W1C         | 0x0                | <p>TxfifoUndrn<br/>FIFO Underrun</p> <p>Applies to IN endpoints only. The core generates this interrupt when it detects a transmit FIFO under-run condition for this endpoint. Dependency: This interrupt is valid only when both of the following conditions are true: Parameter OTG_ENDED_TX_FIFO==1, Threshold 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_ENDED_TX_FIFO==1, Threshold is enabled.</p>                                                                                                                                                                                          |
| 7          | W1C         | 0x0                | <p>TxFEmp<br/>Transmit FIFO Empty</p> <p>This bit is valid only for IN Endpoints. This interrupt is asserted when the Tx FIFO for this endpoint is either half or completely empty. The half or completely empty status is determined by the Tx FIFO Empty Level bit in the Core AHB Configuration register (GAHBCFG.NPTxFEmpLvl).</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 6          | W1C         | 0x0                | <p>INEPNakEff<br/>IN Endpoint NAK Effective</p> <p>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 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.</p> <p>This bit indicates that the core has received more than three back-to-back SETUP packets for this particular endpoint.</p> |
| 5          | W1C         | 0x0                | <p>INTknEPMis<br/>IN Token Received with EP Mismatch</p> <p>Applies to non-periodic IN endpoints only. Indicates that the data in the top of the non-periodic Tx FIFO 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)</p> <p>This interrupt is valid only for Control OUT endpoints and only in Scatter Gather DMA mode.</p>                                                                                                                                                                                                                                                                                                                                     |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4          | W1C         | 0x0                | <p>INTknTxFEmp<br/>IN Token Received When TxFIFO is Empty<br/>Indicates that an IN token was received when the associated TxFIFO periodic/non-periodic) was empty. This interrupt is asserted on the endpoint for which the IN token was received.</p> <p>OUT Token Received When Endpoint Disabled (OUTTknEPdis)<br/>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.</p>                                                                                                                                                                                                                    |
| 3          | W1C         | 0x0                | <p>TimeOUT<br/>Timeout Condition<br/>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.</p> <p>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.</p>                                  |
| 2          | W1C         | 0x0                | <p>AHBErr<br/>AHB Error<br/>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.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 1          | W1C         | 0x0                | <p>EPDisbld<br/>Endpoint Disabled Interrupt<br/>Applies to IN and OUT endpoints. This bit indicates that the endpoint is disabled per the application's request.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 0          | W1C         | 0x0                | <p>XferCompl<br/>Transfer Completed Interrupt<br/>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.</p> |

**USBOTG\_DOEPTSIZEn**

Address: Operational Base + offset (0x0b10)

Device endpoint n transfer size register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 30:29      | RW          | 0x0                | <p>MC<br/>Multi Count</p> <p>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.</p> <p>2'b01: 1 packet<br/>2'b10: 2 packets<br/>2'b11: 3 packets</p> <p>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 Device Endpoint-n Control register (DIEPCTLn.NextEp). Received Data PID (RxDPID)</p> <p>Applies to isochronous OUT endpoints only. This is the data PID received in the last packet for this endpoint.</p> <p>2'b00: DATA0<br/>2'b01: DATA2<br/>2'b10: DATA1<br/>2'b11: MDATA</p> <p>SETUP Packet Count (SUPCnt). Applies to control OUT Endpoints only. This field specifies the number of back-to-back SETUP data packets the endpoint can receive.</p> <p>2'b01: 1 packet<br/>2'b10: 2 packets<br/>2'b11: 3 packets</p> |
| 28:19      | RW          | 0x000              | <p>PktCnt<br/>Packet Count</p> <p>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 coreConsultant configuration (parameter OTG_PACKET_COUNT_WIDTH).</p> <p>IN Endpoints: This field is decremented every time a packet (maximum size or short packet) is read from the TxFIFO.</p> <p>OUT Endpoints: This field is decremented every time a packet (maximum size or short packet) is written to the RxFIFO.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 18:0 | RW   | 0x000000    | XferSize<br>Transfer Size<br>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 coreConsultant configuration (parameter OTG_TRANS_COUNT_WIDTH). The core only interrupts the application after it has exhausted 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 decrements this field every time a packet from the external memory is written to the TxFIFO. OUT Endpoints: The core decrements this field every time a packet is read from the RxFIFO and written to the external memory. |

**USBOTG\_DOEPDMAn**

Address: Operational Base + offset (0x0b14)

Device Endpoint-n DMA Address Register

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | DMAAddr<br>DMA Address<br>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.<br><br>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)

Device endpoint-n DMA buffer address register

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                 |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | DMABufferAddr<br>DMA Buffer Address<br>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\_DOEPCCTLn**

Address: Operational Base + offset (0x0b20)

Device endpoint-n control register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | R/W<br>SC   | 0x0                | <p>EPEna<br/>Endpoint Enable</p> <p>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:</p> <p>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.</p> |
| 30         | R/W<br>SC   | 0x0                | <p>EPDis<br/>Endpoint Disable</p> <p>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.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 29         | RO          | 0x0                | <p>SetD1PID<br/>Field0001 Abstract</p> <p>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 Scatter/Gather DMA mode and 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.</p>                                                                                                                                                                                                                                                                                                                                                                                                    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 28         | WO          | 0x0                | <p>SetD0PID<br/>Set DATA0 PID</p> <p>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 (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 received descriptor structure.</p>                                                                                                                                                                                                                                                |
| 27         | WO          | 0x0                | <p>SNAK<br/>Set NAK</p> <p>Applies to IN and OUT endpoints. 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 OUT endpoints on a Transfer Completed interrupt, or after a SETUP is received on the endpoint.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 26         | WO          | 0x0                | <p>CNAK<br/>Clear NAK</p> <p>Applies to IN and OUT endpoints. A write to this bit clears the NAK bit for the endpoint.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 25:22      | RW          | 0x0                | <p>TxFNum<br/>Tx FIFO Number</p> <p>Shared FIFO Operation: non-periodic endpoints must set this bit to zero. Periodic endpoints must map this to the corresponding Periodic Tx FIFO number. 4'h0: Non-Periodic Tx FIFO; Others: Specified Periodic Tx FIFO 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 using coreConsultant, 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.</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 21         | RW          | 0x0                | <p>Stall<br/>STALL Handshake</p> <p>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.</p> <p>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.</p> |
| 20         | RW          | 0x0                | <p>Snp<br/>Snoop Mode</p> <p>Applies to OUT endpoints only. 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.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 19:18      | RW          | 0x0                | <p>EPType<br/>Endpoint Type</p> <p>Applies to IN and OUT endpoints. This is the transfer type supported by this logical endpoint.</p> <p>2'b00: Control<br/>2'b01: Isochronous<br/>2'b10: Bulk<br/>2'b11: Interrupt</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 17         | RO          | 0x0                | <p>NAKsts<br/>NAK Status</p> <p>Applies to IN and OUT endpoints. Indicates the following:</p> <p>1'b0: The core is transmitting non-NAK handshakes based on the FIFO status.</p> <p>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.</p>                                                                                                                                                                                                                                                                                                                              |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16         | RO          | 0x0                | <p>DPID<br/>Endpoint Data PID<br/>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.</p> <p>1'b0: DATA0<br/>1'b1: DATA1</p> <p>This field is applicable both for Scatter/Gather DMA mode and non-Scatter/Gather DMA mode. Even/Odd (Micro) Frame (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.</p> <p>1'b0: Even (micro)frame<br/>1'b1: Odd (micro)frame</p> <p>When Scatter/Gather DMA mode is enabled, this field is reserved. The frame number in which to send data is provided in the transmit descriptor structure. The frame in which data is received is updated in receive descriptor structure.</p> |
| 15         | R/W SC      | 0x0                | <p>USBActEP<br/>USB Active Endpoint<br/>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 registers accordingly and set this bit.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 14:11      | RW          | 0x0                | <p>NextEp<br/>Next Endpoint<br/>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.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                            |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10:0       | RW          | 0x000              | MPS<br>Maximum Packet Size<br>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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:14      | RW          | 0x0802e            | <p>RestoreValue<br/>Restore Value<br/>(Applicable only when Hibernation is enabled<br/>(OTG_EN_PWR0PT=2). Defines port clock select for different speeds.</p> <ul style="list-style-type: none"> <li>[31] if_dev_mode           <ul style="list-style-type: none"> <li>- 1: Device mode, core restored as device</li> <li>- 0: Host mode, core restored as host</li> </ul> </li> <li>[30:29] p2hd_prt_spd (PRT speed)           <ul style="list-style-type: none"> <li>- 00: HS</li> <li>- 01: FS</li> <li>- 10: LS</li> <li>- 11: Reserved</li> </ul> </li> <li>[28:27] p2hd_dev_enum_spd (Device enumerated speed)           <ul style="list-style-type: none"> <li>- 00: HS</li> <li>- 01: FS (30/60 MHz clk)</li> <li>- 10: LS</li> <li>- 11: FS (48 MHz clk)</li> </ul> </li> <li>[26:20] mac_dev_addr (MAC device address) Device address</li> <li>[19] mac_termselect (Termination selection)           <ul style="list-style-type: none"> <li>- 0: HS_TERM (Program for High Speed)</li> <li>- 1: FS_TERM (Program for Full Speed)</li> </ul> </li> <li>[18:17] mac_xcvrselect (Transceiver select)           <ul style="list-style-type: none"> <li>- 00: HS_XCVR (High Speed)</li> <li>- 01: FS_XCVR (Full Speed)</li> <li>- 10: LS_XCVR (Low Speed)</li> <li>- 11: LFS_XCVR (Reserved)</li> </ul> </li> <li>[16] sh2pl_prt_ctl[0]           <ul style="list-style-type: none"> <li>- 1: prt_power enabled</li> <li>- 0: prt_power disabled</li> </ul> </li> <li>[15:14] prt_clk_sel (Refer prt_clk_sel table)</li> </ul> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13         | RW          | 0x0                | <p>EssRegRestored<br/>Essential Register Values Restored<br/>(Applicable only when Hibernation is enabled (OTG_EN_PWRROPT=2). When a value of 1 is written to this field, it indicates that register values of essential registers have been restored.</p>                                                                                                                                                                                                                                                                                                             |
| 12:10      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 9          | RO          | 0x0                | <p>RestoreMode<br/>Restore Mode<br/>(Applicable only when Hibernation is enabled (OTG_EN_PWRROPT=2). The application should program this bit to specify the restore mode during RESTORE POINT before programming PCGCCTL.EssRegRest bit is set.<br/>Host Mode:<br/>1'b0: Host Initiated Resume, Host Initiated Reset<br/>1'b1: Device Initiated Remote Wake up<br/>Device Mode:<br/>1'b0: Device Initiated Remote Wake up<br/>1'b1: Host Initiated Resume, Host Initiated Reset</p>                                                                                    |
| 8          | RW          | 0x0                | <p>ResetAfterSusp<br/>Reset After Suspend<br/>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 suspend. If this bit is not set, then the host issues resume after suspend. This bit is not 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 wait_restore.</p> |
| 7          | RO          | 0x0                | <p>L1Suspended<br/>Deep Sleep<br/>This bit indicates that the PHY is in deep sleep when in L1 state.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 6          | RO          | 0x0                | <p>PhySleep<br/>PHY in Sleep<br/>This bit indicates that the PHY is in the Sleep state.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 5          | RW          | 0x0                | <p>Enbl_L1Gating<br/>Enable Sleep Clock Gating<br/>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.</p>                                                                                                                                                                                                                                                                                                                    |
| 4          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3          | RW          | 0x0                | RstPdwnModule<br>Reset Power-Down Modules<br>This bit is valid only in Partial Power-Down 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.                                                                                 |
| 2          | RW          | 0x0                | PwrClmp<br>Power Clamp<br>This bit is valid only in Partial Power-Down mode (OTG_EN_PWRLOPT = 1). The application 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. |
| 1          | RW          | 0x0                | GateHclk<br>Gate Hclk<br>The application sets this bit to gate hclk to modules other than the AHB Slave and Master and wakeup logic when the USB is suspended or the session is not valid.<br>The application clears this bit when the USB is resumed or a new session starts.                                                    |
| 0          | RW          | 0x0                | StopPclk<br>Stop Pclk<br>The application sets this bit to stop the PHY clock (phy_clk) when the USB is suspended, the session is not valid, or the device is disconnected. The application clears this bit when the USB is resumed or a new session starts.                                                                       |

**USBOTG\_EPBUFO**

Address: Operational Base + offset (0x1000)

Device endpoint 0 / host out channel 0 address

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                 |
|------------|-------------|--------------------|----------------------------------------------------|
| 31:0       | RW          | 0x00000000         | EPBUFO<br>From0x1000 to 0x2000, EPBUF for endport0 |

**USBOTG\_EPBUF1**

Address: Operational Base + offset (0x2000)

Device endpoint 1 / host out channel 1 address

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                 |
|------------|-------------|--------------------|----------------------------------------------------|
| 31:1       | RO          | 0x0                | reserved                                           |
| 0          | RW          | 0x0                | EPBUF1<br>From0x2000 to 0x3000, EPBUF for endport1 |

**USBOTG\_EPBUF2**

Address: Operational Base + offset (0x3000)

Device endpoint 2 / host out channel 2 address

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                 |
|------------|-------------|--------------------|----------------------------------------------------|
| 31:1       | RO          | 0x0                | reserved                                           |
| 0          | RW          | 0x0                | EPBUF2<br>From0x3000 to 0x4000, EPBUF for endport2 |

**USBOTG\_EPBUF3**

Address: Operational Base + offset (0x4000)

Device endpoint 3 / host out channel 3 address

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                 |
|------------|-------------|--------------------|----------------------------------------------------|
| 31:1       | RO          | 0x0                | reserved                                           |
| 0          | RW          | 0x0                | EPBUF3<br>From0x4000 to 0x5000, EPBUF for endport3 |

**USBOTG\_EPBUF4**

Address: Operational Base + offset (0x5000)

Device endpoint 4 / host out channel 4 address

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                 |
|------------|-------------|--------------------|----------------------------------------------------|
| 31:1       | RO          | 0x0                | reserved                                           |
| 0          | RW          | 0x0                | EPBUF4<br>From0x5000 to 0x6000, EPBUF for endport4 |

**USBOTG\_EPBUF5**

Address: Operational Base + offset (0x6000)

Device endpoint 5 / host out channel 5 address

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                 |
|------------|-------------|--------------------|----------------------------------------------------|
| 31:1       | RO          | 0x0                | reserved                                           |
| 0          | RW          | 0x0                | EPBUF5<br>From0x6000 to 0x7000, EPBUF for endport5 |

**USBOTG\_EPBUF6**

Address: Operational Base + offset (0x7000)

Device endpoint 6 / host out channel 6 address

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                 |
|------------|-------------|--------------------|----------------------------------------------------|
| 31:1       | RO          | 0x0                | reserved                                           |
| 0          | RW          | 0x0                | EPBUF6<br>From0x7000 to 0x8000, EPBUF for endport6 |

**USBOTG\_EPBUF7**

Address: Operational Base + offset (0x8000)

Device endpoint 7 / host out channel 7 address

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                 |
|------------|-------------|--------------------|----------------------------------------------------|
| 31:1       | RO          | 0x0                | reserved                                           |
| 0          | RW          | 0x0                | EPBUF7<br>From0x8000 to 0x9000, EPBUF for endport7 |

## 10.7 Interface description

Table 10-1USB OTG 2.0 Interface Description

| Module Pin | Direction | Pad Name                         | pinmux                    |
|------------|-----------|----------------------------------|---------------------------|
| USB0PN     | A         | IO_USB0_PN                       | -                         |
| USBRBIAS   | A         | IO_USB_RBIAS_0                   | -                         |
| USB0PP     | A         | IO_USB0_PP                       | -                         |
| VBUS       | A         | IO_USB_VBUS_0                    | -                         |
| USB0ID     | A         | IO_USB0_ID                       | -                         |
| DRVVBUS    | DP        | IO_PWM0_OTGdrv_G<br>PIO0N7pmui02 | GRF_GPIO0B_IOMUX[15:14]=2 |

**Note:** **A**—Analog pad ;**AP**—Analog power; **AG**—Analog ground ;**DP**—Digital power ;**DG**—Digital ground;

## 10.8 Application Note

### 10.8.1 Suspend Mode

When PHY is in suspend state

- COMMONONNN = 1'b1, 480M clock invalid
- COMMONONNN = 1'b0, 480M clock output available.

Please refer to "Chapter GRF" for configuration details

### 10.8.2 Relative GRF Registers

USBPHY contains 284 bit registers to configure USB PHY. These bits are used to adjust DP/DM SI. Please refer to "Chapter GRF" for more details.

## Chapter 11 USB2.0 Host

### 11.1 Overview

USB2.0 host controller supports fully USB2.0 functions with one EHCI host controller and one OHCI host controller, and each host controller has one USB port. OHCI host controller only supports full-speed and low-speed mode and is used for full-speed devices and low-speed devices. EHCI only supports high-speed mode and is used for high-speed devices. OHCI host controller and EHCI host controller shares the same USB port, EHCI host controller will auto select the owner (OHCI or EHCI) of this USB port depending on the speed mode of attached devices, when selecting OHCI as owner, OHCI host controller will serve for the attached device; when selecting EHCI as owner, EHCI host controller will serve for the attached device.

USB2.0 Host Controller supports the following features:

- Compatible Specifications
  - Universal Serial Bus Specification, Revision 2.0
  - Enhanced Host Controller Interface Specification (EHCI), Revision 1.0
  - Open Host Controller Interface Specification (OHCI), Revision 1.0a
- Support High-speed (480Mbps), Full-speed (12Mbps) and Low-speed (1.5Mbps)

### 11.2 Block Diagram

USB2.0 Host Controller comprises with:

- EHCI Host Controller: Perform High-speed transactions
- OHCI Host Controller: Perform full/low-speed transactions
- Port Routing Control: Select EHCI Host Controller or OHCI Host Controller



Fig. 11-1 USB2.0 Host Controller Block Diagram

### 11.3 Function Description

#### 11.3.1 EHCI Host Controller

It performs descriptors and data read or write from or to system memory and packs or unpack USB transactions from or to UTMI+ interface defined in EHCI specification for high-speed data transmission.

#### 11.3.2 OHCI Host Controller

It performs descriptors and data read/write from/to system memory and packs or un-pack USB transactions from or to UTMI+ interface defined in OHCI specification for full-speed or low-speed data transmission.

### 11.3.3 Port Routing Control

As part of logic in the EHCI host controller, it is used to auto-select EHCI or OHCI host controller to serve the attached device depending on the speed of the attached device.

## 11.4 Register Description

### 11.4.1 Internal Address Mapping

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

Table 11-1 USB2.0 Host Controller Address Mapping

| Base Address[16] | Device | Address Length | Offset Address Range |
|------------------|--------|----------------|----------------------|
| 1'b0             | EHCI   | 64K BYTE       | 0x00000 ~ 0xfffff    |
| 1'b1             | OHCI   | 64K BYTE       | 0x10000 ~ 0x1fffff   |

EHCI and OHCI register definitions, please refer to Enhanced Host Controller Interface Specification (EHCI), Revision 1.0 and Open Host Controller Interface Specification (OHCI), Revision 1.0a.

## 11.5 Interface Description

Table 11-2 USB2.0 PHY Interface Description

| Module Pin | Direction | Pad Name      | Descriptions                                  |
|------------|-----------|---------------|-----------------------------------------------|
| USB0ID     | I         | IO_USB0_ID    | USB2.0 PHY OTG Port ID, left unused for TypeC |
| USB0PN     | I/O       | IO_USB0_PN    | USB2.0 PHY OTG Port PN                        |
| USB0PP     | I/O       | IO_USB0_PP    | USB2.0 PHY OTG Port PP                        |
| VBUS       | I         | IO_USB0_VBUS  | USB2.0 PHY OTG Port VBUS                      |
| USB1PN     | I/O       | IO_USB1_PN    | USB2.0 PHY Host Port PN                       |
| USB1PP     | I/O       | IO_USB1_PP    | USB2.0 PHY Host Port PP                       |
| USBRBIAS   | I/O       | IO_USB0_RBIAS | USB2.0 PHY Shared RBIAS                       |

## 11.6 Application Notes

### 11.6.1 Special Setting

### 11.6.2 Program flow

Please refer to Enhanced Host Controller Interface Specification (EHCI), Revision 1.0 and Open Host Controller Interface Specification (OHCI), Revision 1.0a.

## Chapter 12 MIPI DSI HOST Controller

### 12.1 Overview

The Display Serial Interface (DSI) is part of a group of communication protocols defined by the MIPI Alliance. The MIPI DSI HOST Controller is a digital core that implements all protocol functions defined in the MIPI DSI Specification. The MIPI DSI HOST Controller provides an interface between the system and the MIPI D-PHY, allowing the communication with a DSI-compliant display. The MIPI DSI HOST Controller supports one to four lanes for data transmission with MIPI D-PHY.

The MIPI DSI HOST Controller supports the following features:

- Compliant with MIPI Alliance standards
- Support the DPI interface color coding mappings into 24-bit Interface
  - 16 bits per pixel, configurations 1,2, and 3
  - 18 bits per pixel, configurations 1 and 2
  - 24 bits per pixel
- Programmable polarity of all DPI interface signals
- Extended resolutions beyond the DPI standard maximum resolution of 800x480 pixels:
  - Up to 2047 vertical active lines
  - Up to 63 vertical back porch lines
  - Up to 63 vertical front porch lines
  - Maximum resolution is limited by available DSI Physical link bandwidth which depends on the number of lanes and maximum speed per lane
- Interface with MIPI D-PHY following PHY Protocol Interface (PPI), as defined in MIPI Alliance Specification for D-PHY
- Up to four D-PHY Data Lanes
- Bidirectional communication and escape mode support through data lane 0
- Transmission of all generic commands
- ECC and Checksum capabilities
- End of Transmission Packet(EOTP)
- Ultra Low-Power mode
- Fault recovery schemes

### 12.2 Block Diagram

The following diagram shows the MIPI DSI HOST Controller architecture.



Fig. 12-1 MIPI DSI HOST Controller architecture

The DPI interface captures the data and control signals and conveys them to a FIFO for video control signals and another one for pixel data. This data is then used to build Video packets, hen in Video mode.

The Register Bank is accessible through a standard AMBA-APB slave interface, providing access to the MIPI DSI HOST Controller registers for configuration and control. There is also a fully programmable interrupt generator to inform the system about certain events.

The PHY Interface Control is responsible for managing the D-PHY PPI interface. It acknowledges the current operation and enables low-power transmission/reception or a high-speed transmission. It also performs data splitting between available D-PHY lanes for high-speed transmission.

The Packet Handler schedules the activities inside the link. It performs several functions based on the interfaces that are currently DPI and the video transmission mode that is used (burst mode or non-burst mode with sync pulse or sync events). It builds long or short packet generating correspondent ECC and CRC codes. This block also performs the following functions: Packet reception, Validation of packet header by checking the ECC, Header correction and notification for single-bit errors, Termination of reception, Multiple header error notification.

The APB-to-Generic block bridges the APB operations into FIFOs holding the Generic commands. The block interfaces with the following FIFOs: Command FIFO, Write payload FIFO, Read payload FIFO.

The Error Management notifies and monitors the error conditions on the DSI link. It controls the timers used to determine if a timeout condition occurred, performing an internal soft reset and triggering an interruption notification.

## 12.3 Function Description

### 12.3.1 DPI interface function

The DPI interface follows the MIPI DPI specification with pixel data bus width up to 24 bits. It is used to transmit the information in Video mode in which the transfers from the host processor to the peripheral take the form of a real-time pixel stream. This interface allows sending ShutDown (SD) and ColorMode (CM) commands, which are triggered directly by writing to the register of CFG\_MISC\_CON[2:1]. To transfer additional commands(for example, to initialize the display), use another interface such as APB Slave Generic Interface to complement the DPI interface.

The DPI interface captures the data and control signals and conveys them to the FIFO interfaces that transmit them to the DSI link. Two different streams of data are presented at

the interface; video control signals and pixel data. Depending on the interface color coding, the pixel data is disposed differently throughout the dpipixdata bus. The following table shows the Interface pixel color coding.

Table 12-1 Color table

| Signal Line  | 16-bit   |          |          | 18-bit   |          | 24-bit |
|--------------|----------|----------|----------|----------|----------|--------|
|              | Config1  | Config2  | Config3  | Config1  | Config2  |        |
| dpipixdata23 | Not used | R7     |
| dpipixdata22 | Not used | R6     |
| dpipixdata21 | Not used | Not used | R4       | Not used | R5       | R5     |
| dpipixdata20 | Not used | R4       | R3       | Not used | R4       | R4     |
| dpipixdata19 | Not used | R3       | R2       | Not used | R3       | R3     |
| dpipixdata18 | Not used | R2       | R1       | Not used | R2       | R2     |
| dpipixdata17 | Not used | R1       | R0       | R5       | R1       | R1     |
| dpipixdata16 | Not used | R0       | Not used | R4       | R0       | R0     |
| dpipixdata15 | R4       | Not used | Not used | R3       | Not used | G7     |
| dpipixdata14 | R3       | Not used | Not used | R2       | Not used | G6     |
| dpipixdata13 | R2       | G5       | G5       | R1       | G5       | G5     |
| dpipixdata12 | R1       | G4       | G4       | R0       | G4       | G4     |
| dpipixdata11 | R0       | G3       | G3       | G5       | G3       | G3     |
| dpipixdata10 | G5       | G2       | G2       | G4       | G2       | G2     |
| dpipixdata9  | G4       | G1       | G1       | G3       | G1       | G1     |
| dpipixdata8  | G3       | G0       | G0       | G2       | G0       | G0     |
| dpipixdata7  | G2       | Not used | Not used | G1       | Not used | B7     |
| dpipixdata6  | G1       | Not used | Not used | G0       | Not used | B6     |
| dpipixdata5  | G0       | Not used | B5       | B5       | B5       | B5     |
| dpipixdata4  | B4       | B4       | B4       | B4       | B4       | B4     |
| dpipixdata3  | B3       | B3       | B3       | B3       | B3       | B3     |
| dpipixdata2  | B2       | B2       | B2       | B2       | B2       | B2     |
| dpipixdata1  | B1       | B1       | B1       | B1       | B1       | B1     |
| dpipixdata0  | B0       | B0       | Not used | B0       | B0       | B0     |

The DPI interface can be configured to increase flexibility and promote correct usage of this interface for several systems. These configuration options are as follows:

- Polarity control: All the control signals are programmable to change the polarity depending on system requirements.

After the MIPI DSI HOST Controller reset, DPI waits for the first VSYNC active transition to start signal sampling, including pixel data, and preventing image transmission in the middle of a frame.

If interface pixel color coding is 18 bits and the 18-bit loosely packed stream is disabled, the number of lines programmed in the pixels per lines configuration is a multiple of four. This means that in this mode, the two LSBs in the configuration are always inferred as zero. The specification states that in this mode, the pixel line size should be a multiple of four.

### 12.3.2 APB Slave Generic Interface

The APB Slave interface allows the transmission of generic information in Command mode, and follows the proprietary register interface. Commands sent through this interface are not constrained to comply with the DCS specification, and can include generic commands described in the DSI specification as manufacturer-specific.

The MIPI DSI HOST Controller supports the transmission or write and read command mode packets as described in the DSI specification. These packets are built using the APB register access. The GEN\_PLD\_DATA register has two distinct functions based on the operation.

Writing to this register sends the data as payload when sending a Command mode packet. Reading this register returns the payload of a read back operation. The GEN\_HDR register contains the Command mode packet header type and header data. Writing to this register

triggers the transmission of the packet implying that for a long Command mode packet, the packet's payload needs to be written in advance in the GEN\_PLD\_DATA register.

The valid packets available to be transmitted through the Generic interface are as follows:

- Generic Write Short Packet 0 Parameters
- Generic Write Short Packet 1 Parameters
- Generic Write Short Packet 2 Parameter
- Generic Write Short Packet 0 Parameter
- Generic Write Short Packet 1 Parameters
- Generic Write Short Packet 2 Parameter
- Maximum Read Packet Configuration
- Generic Long Write Packet
- DCS Write Short Packet 0 Parameter
- DCS Write Short Packet 1 Parameter
- DCS Write Short Packet 0 Parameter
- DCS Write Long Packet

A set of bits in the CMD\_PKT\_STATUS register report the status of the FIFOs associated with APB interface support.

Generic interface packets are always transported using one of the DSI transmission modes; Video mode or Command mode. If neither of these mode are selected, the packets are not transmitted through the link and the released FIFOs eventually get overflowed.

The transfer of packets through the APB bus is based on the following conditions:

The APB protocol defines that the write and read procedure takes two clock cycles each to be executed. This means that the maximum input data rate through the APB interfaces is always half the speed of the APB clock.

The data input bus has a maximum width of 32 bits. This allows for a relation to be defined between the input APB clock frequency and maximum bi rate achievable by the APB interface.

The DSI link bit rate when using solely APB is equal to (APB clock frequency) \*16 Mbps.

The bandwidth is dependent on the APB clock frequency; the available bandwidth increases with the clock frequency.

To drive the APB interface to achieve high bandwidth Command mode traffic transported by the DSI link, the MIPI DSI HOST Controller should operate in the Command mode only and the APB interface should be the only data source that is currently in use. Thus, the APB interface has the entire bandwidth of the DSI link and does not share it with any another input interface source.

The memory write commands require maximum throughout from the APB interface, because they contain the most amount of data conveyed by the DSI link. While writing the packet information, first write the payload of a given packet into the payload FIFO using the GEN\_PLD\_DATA register. When the payload data is for the command parameters, place the first byte to be transmitted in the least significant byte position of the APB data bus.

After writing the payload, write the packet header into the command FIFO. For more information and it should follow the pixel to byte conversion organization referred in the Annexure A of the DCS specification. The follow figures show how the pixel data should be organized in the APB data write bus. The memory write commands are conveyed in DCS long packets. DCS long packets are encapsulated in a DSI packet. The DSI included in the diagrams. In the follow figures, the Write Memory Command can be replaced by the DCS command Write Memory Start and Write Memory Continue.



Fig. 12-2 24bpp APB Pixel to Byte Organization



Fig. 12-3 18 bpp APB Pixel to Byte Organization



Fig. 12-4 16 bpp APB Pixel to Byte Organization



Fig. 12-5 12 bpp APB Pixel to Byte Organization



Fig. 12-6 8bpp APB Pixel to Byte Organization

### 12.3.3 Transmission of Commands in Video Mode

The MIPI DSI HOST Controller supports the transmission of commands, both in high-speed and low-power, while in Video mode. The DSI controller uses Blanking or Low-Power(BLLP) periods to transmit commands inserted through the APB Generic interface. Those periods correspond to the shaded areas of the following figure.



Fig. 12-7 Command Transmission Periods within the Image Area

Commands are transmitted in the blanking periods after the following packet/states:

- Vertical Sync Start (VSS) packets, if the Video Sync pulses are not enabled
- Horizontal Sync End (HSE) packets, in the VSA, VBP, and VFP regions
- Horizontal Sync Start (HSS) packets, if the Video Sync pulses are not enabled in the VSA, VBP, and VFP regions
- Horizontal Active (HACT) state

Only one command is transmitted per line, even in the case of the last line of a frame but one command is possible for each line.

The MIPI DSI HOST Controller avoids sending commands in the last line because it is possible that the last line is shorter than the other ones. For instance, the line time (tL) could be half a cycle longer than the tL on the DPI interface, that is, each line in the frame taking half a cycle from time for the last line. This results in the last line being (1/2 cycle) \*

(number of lines -1) shorter than tL.

The dpicolorm and dpishutdn input signals are also able to trigger the sending of command packets. The commands are DSI data types Color Mode On, Color Mode Off, Shut Down Peripheral, and Turn on Peripheral. These commands are not sent in the VACT region. If the lpcmden bit of the VID\_MODE\_CFG register is 1, these commands are sent in LP mode. In LP mode, the ouvact\_lpcmd\_time field of the LP\_CMD\_TIM register is used to determine if these commands can be transmitted. It is assumed that outvact\_lpcmd\_time is greater than or equal to 4 bytes (number of bytes in a short packet), because the DSI HOST does not transmit these commands on the last line.

If the frame\_BTA\_ack field is set in the VID\_MODE\_CFG register, a BTA is generated by DSI HOST after the last line of a frame. This may coincide with a write command or a read command. In either case, the edpihalt signal is held asserted until an acknowledge has been received (control of the DSI bus is returned to the host).

If the lpcmden bit of the VID\_MODE\_CFG register is set to 1, the commands are sent in low-power in Video mode. In this case, it is necessary to calculate the time available, in bytes, to transmit a command in LP mode for Horizontal Front Porch (HFP), Vertical Sync Active (VSA), Vertical Back Porch (VBP), and Vertical Front Porch(VFP) regions.

The outvact\_lpcmd\_time field of the LP\_CMD\_TIM register indicates the time available (in bytes) to transmit a command in LP mode, based on the escape clock, on a line during the VSA, VBP, and the VFP

$\text{Outvact\_lpcmd\_time} = (\text{tL} - (\text{Time to transmit HSS and HSE frames} + \text{tHSA} + \text{Time to enter and leave LP mode} + \text{Time to send the D-PHY LPDT command})) / \text{escape clock period} / 8 / 2$

Where,

tL=Line time

tHSA=Time to send a short packet (for sync events) or time of the HAS pulse (for sync pulses)

In the above equation, division by eight is done to convert the time available to bytes and division by two is done because one bit is transmitted once in every two escape clock cycles. The outvact\_lpcmd\_time filed can be compared directly with the size of the command to be transmitted to determine if there is enough time to transmit the command. The maximum size of a command that can be transmitted in LP mode is limited to 255 bytes by this field. This register must be programmed to a value greater than or equal to 4 bytes for the transmission of the DCTRL commands such as shutdown and colorm in LP mode.

Consider an example with 12.6  $\mu\text{s}$  per line and assume an escape clock frequency of 15 MHz. In this case, 189 escape clock cycles are available to enter and exit LP mode and transmit command. The following are assumed:

Sync pulses are not being transmitted

Two lane byte clock ticks are required to transmit a short packet

```
phy_lp2hs_time=16
phy_lp2p_time=20
```

In this example, a 11-byte command can be transmitted as follows:

$\text{outvact\_lpcmd\_time} = (12.6\mu\text{s} - (2*10 \text{ ns}) - (16*10 \text{ ns}) - (20*10 \text{ ns}) - (8*66 \text{ ns})) / 66 \text{ ns} / 8 / 2$   
 $= 11 \text{ bytes}$

The invact\_lpcmd\_time field of the LP\_CMD\_TIM register indicates the time available (in bytes) to transmite a command in LP mode (based on the escape clock) in the Vertical Active (VACT) region. This time is calculated as follows:

$\text{Invact\_lpcmd\_time} = ((\text{tHFP} - \text{Time to enter and leave low-power mode} + \text{Blanking period before the HFP when in Burst mode} - \text{Time to send the D-PHY LPDT command}) / \text{escape clock period}) / 8$

Where,

tHFP=line time-tHSA-tHBP-tHACT

tHACT=vid\_pkt\_size\*bits\_per\_pixel\*lane\_byte\_clock\_period / num\_lanes

The invact\_lpcmd\_time field can be compared directly with the size of the command to be transmitted to determined if there is time to transmit the command.

Consider an example where the refresh rate is 60 Hz. The number of lines is 1320 (typical). The tL in this case is 12.6 $\mu\text{s}$ . With a lane byte clock of 100 MHz, 1260 clock ticks are availabel to transmit a single frame. If 800 ticks are used for pixel data then 460 ticks

(4.6 $\mu$ s) are available for Horizontal Sync Start (HSS), HFP, and HBP. Assuming that 2.3 $\mu$ s is available for HFP and the escape clock is 15MHz, only 34 LP clock ticks are available to enter LP, transmit a command, and return from LP mode. Approximately 12 escape clock ticks are required to enter and leave LP mode. Therefore, only 1 byte could be transmitted in this period.

A short packet (for example, generic short write) requires a minimum of 4 bytes. Therefore, in this example, commands are not sent in the VACT region. If Burst mode is enabled, more time is available to transmit commands in the VACT region. The following are assumed:

The controller is not in Burst mode

```
phy_lp2hs_time=16
phy_lp2hs_time=16
```

In this example invact\_lpcmd\_time is calculated as follows:

$$\text{Invact_lpcmd_time} = (2.3\mu\text{s} - (16*10\text{ ns}) - (20*10\text{ ns}) - (8*66\text{ ns})) / 66\text{ ns} / 8 = 2 \text{ bytes}$$

The outvact\_lpcmd\_time and invact\_lpcmd\_time fields allow a simple comparison to determine if a command can be transmitted in any of the BLLP periods.

Following figure illustrates the meaning of invact\_lpcmd\_time and outvact\_lpcmd\_time, matching them with the shaded areas and the VACT region.



Fig. 12-8 Location in the Image Area

If the lpcmden bit of the VID\_MODE\_CFG register is 0, the commands are sent in high\_speed in Video Mode. In this case, the DSI HOST automatically determines the area where each command can be sent and no programming or calculation is required.

On read command transmission, the max\_rd\_time field of the PHY\_TMR\_CFG register configures the maximum amount of time required to perform a read command in lane byte clock cycles.

The maximum time required to perform a read command in Lane byte clock cycles (max\_rd\_time) = Time to transmit the read command in LP mode + Time to enter and leave LP mode + Time to return the read data packet from the peripheral device.

The time to return the read data packet from the peripheral depends on the number of bytes read and the escape clock frequency of the peripheral; not the escape clock of the host. The max\_rd\_time field is used in both HS and LP mode to determine if there is time to complete a read command in a BLLP period.

In high-speed mode (lpcmden=0), max\_rd\_time is calculated as follows:

max\_rd\_time = phy\_hs2lp\_time + Time to return the read data packet from the peripheral device + phy\_hs2hs\_time

In low-power mode (lpcmden = 1), max\_rd\_time is calculated as follows:

max\_rd\_time = phy\_hs2lp\_time + LPDT command time + Read command time in LP mode + Time to return the data read from the peripheral device + phy\_lp2hs\_time

Where,

LPDT command time = (8\*Host escape clock period) / Lane byte clock period

Read command time in LP mode = (32 \* host escape clock period) / lane byte clock period

It is recommended to keep the maximum number of bytes read from the peripheral to a

minimum to have sufficient time available to issue the read commands on a line. Ensure that max\_rd\_time\* Lane byte clock period is less than outvact\_lpcmd\_time \*8\*Escape clock period of the host.

Otherwise, the read commands are serviced on the last line of a frame and the edpihalt signal may be asserted. If it is necessary to read a large number of parameters (>16), increase the max\_rd\_time while the read command is being executed. When the read has completed, decrease the max\_rd\_time to a lower value.

## 12.4 Register Description

### 12.4.1 Internal Address Mapping

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

### 12.4.2 Registers Summary

| Name                            | Offset | Size | Reset Value | Description                                                                                                              |
|---------------------------------|--------|------|-------------|--------------------------------------------------------------------------------------------------------------------------|
| MIPI_DSI_HOST_VERSIO_N          | 0x0000 | W    | 0x3133302a  | VERSION                                                                                                                  |
| MIPI_DSI_HOST_PWR_UP            | 0x0004 | W    | 0x00000000  | power-up of the miipi dsi controller                                                                                     |
| MIPI_DSI_HOST_CLKMGR_CFG        | 0x0008 | W    | 0x00000000  | Clock mgr                                                                                                                |
| MIPI_DSI_HOST_DPI_VCID          | 0x000c | W    | 0x00000000  | DPI_VCID                                                                                                                 |
| MIPI_DSI_HOST_DPI_COL_OR_CODING | 0x0010 | W    | 0x00000000  | DPI_COLOR_CODING                                                                                                         |
| MIPI_DSI_HOST_DPI_CFG_POL       | 0x0014 | W    | 0x00000000  | polarity of the DPI signals                                                                                              |
| MIPI_DSI_HOST_DPI_LP_CMD_TIM    | 0x0018 | W    | 0x00000000  | DPI_LP_CMD_TIM                                                                                                           |
| MIPI_DSI_HOST_PCKHDL_CFG        | 0x002c | W    | 0x00000000  | Register0000 Description                                                                                                 |
| MIPI_DSI_HOST_GEN_VCID          | 0x0030 | W    | 0x00000000  | GEN_VCID                                                                                                                 |
| MIPI_DSI_HOST_MODE_CFG          | 0x0034 | W    | 0x00000001  | This register configures the mode of operation - Video mode or Command mode(Commands can be sent even in video mode too) |
| MIPI_DSI_HOST_VID_MODE_CFG      | 0x0038 | W    | 0x00000000  | VID_MODE_CFG                                                                                                             |
| MIPI_DSI_HOST_VID_PKT_SIZE      | 0x003c | W    | 0x00000000  | VID_PKT_SIZE                                                                                                             |
| MIPI_DSI_HOST_VID_NUM_CHUNKS    | 0x0040 | W    | 0x00000000  | VID_NUM_CHUNKS                                                                                                           |
| MIPI_DSI_HOST_VID_NULL_SIZE     | 0x0044 | W    | 0x00000000  | VID_NULL_SIZE                                                                                                            |

| Name                            | Offset | Size | Reset Value | Description       |
|---------------------------------|--------|------|-------------|-------------------|
| MIPI_DSI_HOST_VID_HSA_TIME      | 0x0048 | W    | 0x00000000  | VID_HSA_TIME      |
| MIPI_DSI_HOST_VID_HBP_TIME      | 0x004c | W    | 0x00000000  | VID_HBP_TIME      |
| MIPI_DSI_HOST_VID_HLINE_TIME    | 0x0050 | W    | 0x00000000  | VID_HLINE_TIME    |
| MIPI_DSI_HOST_VID_VSA_LINES     | 0x0054 | W    | 0x00000000  | VID_VSA_LINES     |
| MIPI_DSI_HOST_VID_VBP_LINES     | 0x0058 | W    | 0x00000000  | VID_VBP_LINES     |
| MIPI_DSI_HOST_VID_VFP_LINES     | 0x005c | W    | 0x00000000  | VID_VFP_LINES     |
| MIPI_DSI_HOST_VID_VACTIVE_LINES | 0x0060 | W    | 0x00000000  | VID_VACTIVE_LINES |
| MIPI_DSI_HOST_EDPI_CMD_SIZE     | 0x0064 | W    | 0x00000000  | EDPI_CMD_SIZE     |
| MIPI_DSI_HOST_CMD_MODE_CFG      | 0x0068 | W    | 0x00000000  | CMD_MODE_CFG      |
| MIPI_DSI_HOST_GEN_HDR           | 0x006c | W    | 0x00000000  | GEN_HDR           |
| MIPI_DSI_HOST_GEN_PLD_DATA      | 0x0070 | W    | 0x00000000  | GEN_PLD_DATA      |
| MIPI_DSI_HOST_CMD_PKT_STATUS    | 0x0074 | W    | 0x00000000  | CMD_PKT_STATUS    |
| MIPI_DSI_HOST_TO_CNT_CFG        | 0x0078 | W    | 0x00000000  | TO_CNT_CFG        |
| MIPI_DSI_HOST_HS_RD_TO_CNT      | 0x007c | W    | 0x00000000  | HS_RD_TO_CNT      |
| MIPI_DSI_HOST_LP_RD_TO_CNT      | 0x0080 | W    | 0x00000000  | LP_RD_TO_CNT      |
| MIPI_DSI_HOST_HS_WR_TO_CNT      | 0x0084 | W    | 0x00000000  | HS_WR_TO_CNT      |
| MIPI_DSI_HOST_LP_WR_TO_CNT      | 0x0088 | W    | 0x00000000  | LP_WR_TO_CNT      |
| MIPI_DSI_HOST_BTA_TO_CNT        | 0x008c | W    | 0x00000000  | BTA_TO_CNT        |
| MIPI_DSI_HOST_SDF_3D            | 0x0090 | W    | 0x00000000  | SDF_3D            |
| MIPI_DSI_HOST_LPCLK_CTRL        | 0x0094 | W    | 0x00000000  | LPCLK_CTRL        |
| MIPI_DSI_HOST_PHY_TMR_LPCLK_CFG | 0x0098 | W    | 0x00000000  | PHY_TMR_LPCLK_CFG |
| MIPI_DSI_HOST_PHY_TMR_CFG       | 0x009c | W    | 0x00000000  | PHY_TMR_CFG       |

| Name                               | Offset | Size | Reset Value | Description          |
|------------------------------------|--------|------|-------------|----------------------|
| MIPI_DSI_HOST_PHY_RS_TZ            | 0x00a0 | W    | 0x00000000  | PHY_RSTZ             |
| MIPI_DSI_HOST_PHY_IF_CFG           | 0x00a4 | W    | 0x00000003  | PHY_IF_CFG           |
| MIPI_DSI_HOST_PHY_STATUS           | 0x00b0 | W    | 0x00000000  | PHY_STATUS           |
| MIPI_DSI_HOST_INT_ST0              | 0x00bc | W    | 0x00000000  | INT_ST0              |
| MIPI_DSI_HOST_INT_ST1              | 0x00c0 | W    | 0x00000000  | INT_ST1              |
| MIPI_DSI_HOST_INT_MS_K0            | 0x00c4 | W    | 0x00000000  | INT_ST0              |
| MIPI_DSI_HOST_INT_MS_K1            | 0x00c8 | W    | 0x00000000  | INT_MSK1             |
| MIPI_DSI_HOST_INT_FO_RCE0          | 0x00d8 | W    | 0x00000000  | INT_FORCE0           |
| MIPI_DSI_HOST_INT_FO_RCE1          | 0x00dc | W    | 0x00000000  | INT_FORCE1           |
| MIPI_DSI_HOST_VID_SHADOW_CTRL      | 0x0100 | W    | 0x00000000  | VID_SHADOW_CTRL      |
| MIPI_DSI_HOST_DPI_VCID_ACT         | 0x010c | W    | 0x00000000  | DPI_VCID_ACT         |
| MIPI_DSI_HOST_DPI_COLOR_CODING_ACT | 0x0110 | W    | 0x00000000  | DPI_COLOR_CODING_ACT |
| MIPI_DSI_HOST_DPI_LP_CMD_TIM_ACT   | 0x0118 | W    | 0x00000000  | DPI_LP_CMD_TIM_ACT   |
| MIPI_DSI_HOST_VID_MODE_CFG_ACT     | 0x0138 | W    | 0x00000000  | VID_MODE_CFG_ACT     |
| MIPI_DSI_HOST_VID_PKT_SIZE_ACT     | 0x013c | W    | 0x00000000  | VID_PKT_SIZE_ACT     |
| MIPI_DSI_HOST_VID_NUM_CHUNKS_ACT   | 0x0140 | W    | 0x00000000  | VID_NUM_CHUNKS_ACT   |
| MIPI_DSI_HOST_VID_NULL_SIZE_ACT    | 0x0144 | W    | 0x00000000  | VID_NULL_SIZE_ACT    |
| MIPI_DSI_HOST_VID_HS_A_TIME_ACT    | 0x0148 | W    | 0x00000000  | VID_HSA_TIME_ACT     |
| MIPI_DSI_HOST_VID_HB_P_TIME_ACT    | 0x014c | W    | 0x00000000  | VID_HBP_TIME_ACT     |
| MIPI_DSI_HOST_VID_HLINE_TIME_ACT   | 0x0150 | W    | 0x00000000  | VID_HLINE_TIME_ACT   |
| MIPI_DSI_HOST_VID_VSA_LINES_ACT    | 0x0154 | W    | 0x00000000  | VID_VSA_LINES_ACT    |
| MIPI_DSI_HOST_VID_VBP_LINES_ACT    | 0x0158 | W    | 0x00000000  | VID_VBP_LINES_ACT    |

| Name                                | Offset | Size | Reset Value | Description           |
|-------------------------------------|--------|------|-------------|-----------------------|
| MIPI_DSI_HOST_VID_VFP_LINES_ACT     | 0x015c | W    | 0x00000000  | VID_VFP_LINES_ACT     |
| MIPI_DSI_HOST_VID_VACTIVE_LINES_ACT | 0x0160 | W    | 0x00000000  | VID_VACTIVE_LINES_ACT |
| MIPI_DSI_HOST_SDF_3D_ACT            | 0x0190 | W    | 0x00000000  | SDF_3D_ACT            |

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

### 12.4.3 Detail Register Description

#### **MIPI\_DSI\_HOST\_VERSION**

Address: Operational Base + offset (0x0000)

| Bit  | Attr | Reset Value | Description        |
|------|------|-------------|--------------------|
| 31:0 | RW   | 0x3133302a  | VERSION<br>VERSION |

#### **MIPI\_DSI\_HOST\_PWR\_UP**

Address: Operational Base + offset (0x0004)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                    |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                       |
| 0    | RW   | 0x0         | shutdownz<br><br>This bit configures the core either to power up or to reset.<br>shutdownz is<br><br>the soft reset register. Its default value is 0. After the core configuration,<br><br>to enable the DWC_mipi_dsi_host, set this register to 1.<br>0: Reset<br>1: Power-up |

#### **MIPI\_DSI\_HOST\_CLKMGR\_CFG**

Address: Operational Base + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0                | reserved                                                                                                                                                                                  |
| 15:8       | RW          | 0x00               | <p>to_clk_division<br/>This field indicates the division factor for the Time Out clock used as<br/>the timing unit in the configuration of HS to LP and LP to HS transition<br/>error</p> |
| 7:0        | RW          | 0x00               | <p>tx_esc_clk_division<br/>This field indicates the division factor for the TX Escape clock source<br/>(lanebyteclk). The values 0 and 1 stop the TX_ESC clock generation</p>             |

**MIPI DSI HOST DPI VCID**

Address: Operational Base + offset (0x000c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------|
| 31:2       | RO          | 0x0                | reserved                                                                                                            |
| 1:0        | RW          | 0x0                | <p>dpi_vcidx<br/>This field configures the DPI virtual channel id that is indexed to the<br/>Video mode packets</p> |

**MIPI DSI HOST DPI COLOR CODING**

Address: Operational Base + offset (0x0010)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:9       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 8          | RW          | 0x0                | <p>loosely18_en</p> <p>When set to 1, this bit activates loosely packed variant to 18-bit configurations</p>                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 7:4        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 3:0        | RW          | 0x0                | <p>dpi_color_coding</p> <p>This field configures the DPI color coding as follows:</p> <ul style="list-style-type: none"> <li>0000: 16-bit configuration 1</li> <li>0001: 16-bit configuration 2</li> <li>0010: 16-bit configuration 3</li> <li>0011: 18-bit configuration 1</li> <li>0100: 18-bit configuration 2</li> <li>0101: 24-bit</li> <li>0110: 20-bit YCbCr 4:2:2 loosely packed</li> <li>0111: 24-bit YCbCr 4:2:2</li> <li>1000: 16-bit YCbCr 4:2:2</li> <li>1001: 30-bit</li> <li>1010: 36-bit</li> <li>1011-1111: 12-bit YCbCr 4:2:0</li> </ul> |

**MIPI DSI HOST DPI CFG POL**

Address: Operational Base + offset (0x0014)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x0                | reserved                                                                                                       |
| 4          | RW          | 0x0                | colorm_active_low<br>When set to 1, this bit configures the color mode pin (dpicolorm) as active low           |
| 3          | RW          | 0x0                | shutd_active_low<br>When set to 1, this bit configures the shutdown pin (dpishutdn) as active low              |
| 2          | RW          | 0x0                | hsync_active_low<br>When set to 1, this bit configures the horizontal synchronism pin (dpihsync) as active low |
| 1          | RW          | 0x0                | vsync_active_low<br>When set to 1, this bit configures the vertical synchronism pin (dpivsync) as active low   |
| 0          | RW          | 0x0                | dataen_active_low<br>When set to 1, this bit configures the data enable pin (dpidataen) as active low          |

**MIPI DSI HOST DPI LP CMD TIM**

Address: Operational Base + offset (0x0018)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24      | RO          | 0x0                | reserved                                                                                                                                                                                                      |
| 23:16      | RW          | 0x00               | outvact_lpcmd_time<br>This field is used for the transmission of commands in low-power mode. It defines the size, in bytes, of the largest packet that can fit in a line during the VSA, VBP, and VFP regions |
| 15:8       | RO          | 0x0                | reserved                                                                                                                                                                                                      |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                        |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0        | RW          | 0x00               | <p>invact_lpcmd_time</p> <p>This field is used for the transmission of commands in low-power mode. It defines the size, in bytes, of the largest packet that can fit in a line during the VACT region</p> |

**MIPI DSI HOST PCKHDL CFG**

Address: Operational Base + offset (0x002c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x0                | reserved                                                                                                   |
| 4          | RW          | 0x0                | <p>crc_rx_en</p> <p>When set to 1, this bit enables the CRC reception and error reporting</p>              |
| 3          | RW          | 0x0                | <p>ecc_rx_en</p> <p>When set to 1, this bit enables the ECC reception, error correction, and reporting</p> |
| 2          | RW          | 0x0                | <p>bta_en</p> <p>When set to 1, this bit enables the Bus Turn-Around (BTA) request</p>                     |
| 1          | RW          | 0x0                | <p>eotp_rx_en</p> <p>When set to 1, this bit enables the EoTp reception</p>                                |
| 0          | RW          | 0x0                | <p>eotp_tx_en</p> <p>When set to 1, this bit enables the EoTp transmission</p>                             |

**MIPI DSI HOST GEN VCID**

Address: Operational Base + offset (0x0030)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------|
| 1:0        | RW          | 0x0                | <p>gen_vcid_rx</p> <p>This field indicates the Generic interface read-back virtual channel identification</p> |

**MIPI DSI HOST MODE CFG**

Address: Operational Base + offset (0x0034)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x0                | reserved                                                                                                                                                        |
| 0          | RW          | 0x1                | <p>cmd_video_mode</p> <p>This bit configures the operation mode:</p> <ul style="list-style-type: none"> <li>■0: Video mode</li> <li>■1: Command mode</li> </ul> |

**MIPI DSI HOST VID MODE CFG**

Address: Operational Base + offset (0x0038)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:25      | RO          | 0x0                | reserved                                                                                                                                                                                    |
| 24         | RW          | 0x0                | <p>vpg_orientation</p> <p>This field indicates the color bar orientation as follows:</p> <ul style="list-style-type: none"> <li>0: Vertical mode</li> <li>1: Horizontal mode</li> </ul>     |
| 23:21      | RO          | 0x0                | reserved                                                                                                                                                                                    |
| 20         | RW          | 0x0                | <p>vpg_mode</p> <p>This field is to select the pattern:</p> <ul style="list-style-type: none"> <li>0: Color bar (horizontal or vertical)</li> <li>1: BER pattern (vertical only)</li> </ul> |
| 19:17      | RO          | 0x0                | reserved                                                                                                                                                                                    |
| 16         | RW          | 0x0                | <p>vpg_en</p> <p>When set to 1, this bit enables the video mode pattern generator</p>                                                                                                       |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------|
| 15         | RW          | 0x0                | lp_cmd_en<br>When set to 1, this bit enables the command transmission only in lowpower mode                                            |
| 14         | RW          | 0x0                | frame_bta_ack_en<br>When set to 1, this bit enables the request for an acknowledge response at the end of a frame                      |
| 13         | RW          | 0x0                | lp_hfp_en<br>When set to 1, this bit enables the return to low-power inside the Horizontal Front Porch (HFP) period when timing allows |
| 12         | RW          | 0x0                | lp_hbp_en<br>When set to 1, this bit enables the return to low-power inside the Horizontal Back Porch (HBP) period when timing allows  |
| 11         | RW          | 0x0                | lp_vact_en<br>When set to 1, this bit enables the return to low-power inside the Vertical Active (VACT) period when timing allows      |
| 10         | RW          | 0x0                | lp_vfp_en<br>When set to 1, this bit enables the return to low-power inside the Vertical Front Porch (VFP) period when timing allows   |
| 9          | RW          | 0x0                | lp_vbp_en<br>When set to 1, this bit enables the return to low-power inside the Vertical Back Porch (VBP) period when timing allows    |
| 8          | RW          | 0x0                | lp_vsa_en<br>When set to 1, this bit enables the return to low-power inside the Vertical Sync Time (VSA) period when timing allows     |
| 7:2        | RO          | 0x0                | reserved                                                                                                                               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0        | RW          | 0x0                | <p>vid_mode_type</p> <p>This field indicates the video mode transmission type as follows:</p> <p>2'b00: Non-burst with sync pulses</p> <p>2'b01: Non-burst with sync events</p> <p>2'b10 and 2'b11: Burst mode</p> |

**MIPI DSI HOST VID PKT SIZE**

Address: Operational Base + offset (0x003c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                               |
| 13:0       | RW          | 0x0000             | <p>vid_pkt_size</p> <p>This field configures the number of pixels in a single video packet. For 18-bit not loosely packed data types, this number must be a multiple of 4. For YCbCr data types, it must be a multiple of 2, as described in the DSI specification</p> |

**MIPI DSI HOST VID NUM CHUNKS**

Address: Operational Base + offset (0x0040)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:13      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 12:0       | RW          | 0x0000             | <p>vid_num_chunks</p> <p>This register configures the number of chunks to be transmitted during a Line period (a chunk consists of a video packet and a null packet).</p> <p>If set to 0 or 1, the video line is transmitted in a single packet.</p> <p>If set to 1, the packet is part of a chunk, so a null packet follows it if vid_null_size &gt; 0. Otherwise, multiple chunks are used to transmit each video line</p> |

**MIPI\_DSI\_HOST\_VID\_NULL\_SIZE**

Address: Operational Base + offset (0x0044)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------|
| 31:13      | RO          | 0x0                | reserved                                                                                                                         |
| 12:0       | RW          | 0x0000             | vid_null_size<br>This register configures the number of bytes inside a null packet.<br>Setting it to 0 disables the null packets |

**MIPI\_DSI\_HOST\_VID\_HSA\_TIME**

Address: Operational Base + offset (0x0048)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------|
| 31:12      | RO          | 0x0                | reserved                                                                                                    |
| 11:0       | RW          | 0x000              | vid_hsa_time<br>This field configures the Horizontal Synchronism Active period in lane<br>byte clock cycles |

**MIPI\_DSI\_HOST\_VID\_HBP\_TIME**

Address: Operational Base + offset (0x004c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------|
| 31:12      | RO          | 0x0                | reserved                                                                                                    |
| 11:0       | RW          | 0x000              | vid_hsa_time<br>This field configures the Horizontal Synchronism Active period in lane<br>byte clock cycles |

**MIPI\_DSI\_HOST\_VID\_HLINE\_TIME**

Address: Operational Base + offset (0x0050)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------|
| 31:15      | RO          | 0x0                | reserved                                                                                                                        |
| 14:0       | RW          | 0x0000             | vid_hline_time<br>This field configures the size of the total line time<br>(HSA+HBP+HACT+HFP) counted in lane byte clock cycles |

**MIPI\_DSI\_HOST\_VID\_VSA\_LINES**

Address: Operational Base + offset (0x0054)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                               |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------|
| 31:10      | RO          | 0x0                | reserved                                                                                                         |
| 9:0        | RW          | 0x000              | vsa_lines<br>This field configures the Vertical Synchronism Active period measured in number of horizontal lines |

**MIPI DSI HOST VID VBP LINES**

Address: Operational Base + offset (0x0058)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                       |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------|
| 31:10      | RO          | 0x0                | reserved                                                                                                 |
| 9:0        | RW          | 0x000              | vbp_lines<br>This field configures the Vertical Back Porch period measured in number of horizontal lines |

**MIPI DSI HOST VID VFP LINES**

Address: Operational Base + offset (0x005c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                        |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x0                | reserved                                                                                                  |
| 0          | RW          | 0x0                | vfp_lines<br>This field configures the Vertical Front Porch period measured in number of horizontal lines |

**MIPI DSI HOST VID VACTIVE LINES**

Address: Operational Base + offset (0x0060)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                        |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------|
| 31:14      | RO          | 0x0                | reserved                                                                                                  |
| 13:0       | RW          | 0x0000             | v_active_lines<br>This field configures the Vertical Active period measured in number of horizontal lines |

**MIPI DSI HOST EDPI CMD SIZE**

Address: Operational Base + offset (0x0064)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0                | reserved                                                                                                                                                                                                          |
| 15:0       | RW          | 0x0000             | <p>edpi_allowed_cmd_size</p> <p>This field configures the maximum allowed size for an eDPI write memory command, measured in pixels. Automatic partitioning of data obtained from eDPI is permanently enabled</p> |

**MIPI DSI HOST CMD MODE CFG**

Address: Operational Base + offset (0x0068)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:25      | RO          | 0x0                | reserved                                                                                                                                                               |
| 24         | RW          | 0x0                | <p>max_rd_pkt_size</p> <p>This bit configures the maximum read packet size command transmission type:</p> <p>1'b0: High-speed</p> <p>1'b1: Low-power</p>               |
| 23:20      | RO          | 0x0                | reserved                                                                                                                                                               |
| 19         | RW          | 0x0                | <p>dcs_lw_tx</p> <p>This bit configures the DCS long write packet command transmission type:</p> <p>1'b0: High-speed</p> <p>1'b1: Low-power</p>                        |
| 18         | RW          | 0x0                | <p>dcs_sr_0p_tx</p> <p>This bit configures the DCS short read packet with zero parameter command transmission type:</p> <p>1'b0: High-speed</p> <p>1'b1: Low-power</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 17         | RW          | 0x0                | <p>dcs_sw_1p_tx</p> <p>This bit configures the DCS short write packet with one parameter</p> <p>command transmission type:</p> <p>1'b0: High-speed</p> <p>1'b1: Low-power</p>     |
| 16         | RW          | 0x0                | <p>dcs_sw_0p_tx</p> <p>This bit configures the DCS short write packet with zero parameter</p> <p>command transmission type:</p> <p>1'b0: High-speed</p> <p>1'b1: Low-power</p>    |
| 15         | RO          | 0x0                | reserved                                                                                                                                                                          |
| 14         | RW          | 0x0                | <p>gen_lw_tx</p> <p>This bit configures the Generic long write packet command</p> <p>transmission type:</p> <p>1'b0: High-speed</p> <p>1'b1: Low-power</p>                        |
| 13         | RW          | 0x0                | <p>gen_sr_2p_tx</p> <p>This bit configures the Generic short read packet with two parameters</p> <p>command transmission type:</p> <p>1'b0: High-speed</p> <p>1'b1: Low-power</p> |
| 12         | RW          | 0x0                | <p>gen_sr_1p_tx</p> <p>This bit configures the Generic short read packet with one parameter</p> <p>command transmission type:</p> <p>1'b0: High-speed</p> <p>1'b1: Low-power</p>  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11         | RW          | 0x0                | <p>gen_sr_0p_tx</p> <p>This bit configures the Generic short read packet with zero parameter</p> <p>command transmission type:</p> <p>1'b0: High-speed</p> <p>1'b1: Low-power</p>  |
| 10         | RW          | 0x0                | <p>gen_sw_2p_tx</p> <p>This bit configures the Generic short write packet with two parameters</p> <p>command transmission type:</p> <p>1'b0: High-speed</p> <p>1'b1: Low-power</p> |
| 9          | RW          | 0x0                | <p>gen_sw_1p_tx</p> <p>This bit configures the Generic short write packet with one parameter</p> <p>command transmission type:</p> <p>1'b0: High-speed</p> <p>1'b1: Low-power</p>  |
| 8          | RW          | 0x0                | <p>gen_sw_0p_tx</p> <p>This bit configures the Generic short write packet with zero parameter</p> <p>command transmission type:</p> <p>1'b0: High-speed</p> <p>1'b1: Low-power</p> |
| 7:2        | RO          | 0x0                | reserved                                                                                                                                                                           |
| 1          | RW          | 0x0                | <p>ack_rqst_en</p> <p>When set to 1, this bit enables the acknowledge request after each packet transmission</p>                                                                   |
| 0          | RW          | 0x0                | <p>tear_fx_en</p> <p>When set to 1, this bit enables the tearing effect acknowledge request</p>                                                                                    |

**MIPI DSI HOST GEN HDR**

Address: Operational Base + offset (0x006c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24      | RO          | 0x0                | reserved                                                                                                                                            |
| 23:16      | RW          | 0x00               | gen_wc_msbyte<br>gen_wc_msbyte                                                                                                                      |
| 15:8       | RW          | 0x00               | gen_wc_lsbyte<br>This field configures the least significant byte of the header packet's<br>Word count for long packets or data 0 for short packets |
| 7:6        | RW          | 0x0                | gen_vc<br>This field configures the virtual channel id of the header packet                                                                         |
| 5:0        | RW          | 0x00               | gen_dt<br>This field configures the packet data type of the header packet                                                                           |

**MIPI DSI HOST GEN PLD DATA**

Address: Operational Base + offset (0x0070)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------|
| 31:24      | RW          | 0x00               | gen_pld_b4<br>This field indicates byte 4 of the packet payload |
| 23:16      | RW          | 0x00               | gen_pld_b3<br>This field indicates byte 3 of the packet payload |
| 15:8       | RW          | 0x00               | gen_pld_b2<br>This field indicates byte 2 of the packet payload |
| 7:0        | RW          | 0x00               | gen_pld_b1<br>This field indicates byte 1 of the packet payload |

**MIPI DSI HOST CMD PKT STATUS**

Address: Operational Base + offset (0x0074)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------|
| 14         | RW          | 0x0                | <p>dbi_rd_cmd_busy</p> <p>This bit is set when a read command is issued and cleared when the entire response is stored in the FIFO</p> |
| 13         | RO          | 0x0                | <p>dbi_pld_r_full</p> <p>This bit indicates the full status of the DBI read payload FIFO</p>                                           |
| 12         | RO          | 0x0                | <p>dbi_pld_r_empty</p> <p>This bit indicates the empty status of the DBI read payload FIFO</p>                                         |
| 11         | RO          | 0x0                | <p>dbi_pld_w_full</p> <p>This bit indicates the full status of the DBI write payload FIFO</p>                                          |
| 10         | RO          | 0x0                | <p>dbi_pld_w_empty</p> <p>This bit indicates the empty status of the DBI write payload FIFO</p>                                        |
| 9          | RO          | 0x0                | <p>dbi_cmd_full</p> <p>This bit indicates the full status of the DBI command FIFO</p>                                                  |
| 8          | RO          | 0x0                | <p>dbi_cmd_empty</p> <p>This bit indicates the empty status of the DBI command FIFO</p>                                                |
| 7          | RO          | 0x0                | reserved                                                                                                                               |
| 6          | RO          | 0x0                | <p>gen_rd_cmd_busy</p> <p>This bit is set when a read command is issued and cleared when the entire response is stored in the FIFO</p> |
| 5          | RO          | 0x0                | <p>gen_pld_r_full</p> <p>This bit indicates the full status of the generic read payload FIFO</p>                                       |
| 4          | RO          | 0x0                | <p>gen_pld_r_empty</p> <p>This bit indicates the empty status of the generic read payload FIFO</p>                                     |
| 3          | RO          | 0x0                | <p>gen_pld_w_full</p> <p>This bit indicates the full status of the generic write payload FIFO</p>                                      |
| 2          | RO          | 0x0                | <p>gen_pld_w_empty</p> <p>This bit indicates the empty status of the generic write payload FIFO</p>                                    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------|
| 1          | RO          | 0x0                | gen_cmd_full<br>This bit indicates the full status of the generic command FIFO   |
| 0          | RO          | 0x0                | gen_cmd_empty<br>This bit indicates the empty status of the generic command FIFO |

**MIPI DSI HOST TO CNT CFG**

Address: Operational Base + offset (0x0078)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | <p>hstx_to_cnt</p> <p>This field configures the timeout counter that triggers a high-speed transmission timeout contention detection (measured in TO_CLK_DIVISION cycles).</p> <p>If using the non-burst mode and there is no sufficient time to switch from HS to LP and back in the period which is from one line data finishing to the next line sync start, the DSI link returns the LP state once per frame, then you should configure the TO_CLK_DIVISION and hstx_to_cnt to be in accordance with:</p> $\text{hstx\_to\_cnt} * \text{lanebyteclkperiod} * \text{TO\_CLK\_DIVISION} \geq \text{the time of one FRAME data transmission} * (1 + 10\%)$ <p>In burst mode, RGB pixel packets are time-compressed, leaving more time during a scan line. Therefore, if in burst mode and there is sufficient time to switch from HS to LP and back in the period of time from one line data finishing to the next line sync start, the DSI link can return LP mode and back in this time interval to save power. For this,</p> <p>configure the TO_CLK_DIVISION and hstx_to_cnt to be in accordance with:</p> $\text{hstx\_to\_cnt} * \text{lanebyteclkperiod} * \text{TO\_CLK\_DIVISION} \geq \text{the time of one LINE data transmission} * (1 + 10\%)$ |
| 15:0       | RW          | 0x0000             | <p>lpxr_to_cnt</p> <p>This field configures the timeout counter that triggers a low-power reception timeout contention detection (measured in TO_CLK_DIVISION cycles)</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

**MIPI DSI HOST HS RD TO\_CNT**

Address: Operational Base + offset (0x007c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                 |
| 15:0       | RW          | 0x0000             | <p>hs_rd_to_cnt</p> <p>This field sets a period for which the DWC_mipi_dsi_host keeps the link still, after sending a high-speed read operation. This period is measured in cycles of lanebyteclk. The counting starts when the D-PHY enters the Stop state and causes no interrupts</p> |

**MIPI DSI HOST LP RD TO CNT**

Address: Operational Base + offset (0x0080)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                |
| 15:0       | RW          | 0x0000             | <p>lp_rd_to_cnt</p> <p>This field sets a period for which the DWC_mipi_dsi_host keeps the link still, after sending a low-power read operation. This period is measured in cycles of lanebyteclk. The counting starts when the D-PHY enters the Stop state and causes no interrupts</p> |

**MIPI DSI HOST HS WR TO CNT**

Address: Operational Base + offset (0x0084)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 24         | RW          | 0x0                | <p>presp_to_mode</p> <p>When set to 1, this bit ensures that the peripheral response timeout caused by hs_wr_to_cnt is used only once per eDPI frame, when both the following conditions are met:</p> <ul style="list-style-type: none"> <li>dpisync_edpiwms has risen and fallen.</li> <li>Packets originated from eDPI have been transmitted and its FIFO is empty again.</li> </ul> <p>In this scenario no non-eDPI requests are sent to the D-PHY, even if there is traffic from generic or DBI ready to be sent, making it return to stop state. When it does so, PRESP_TO counter is activated and only when it finishes does the controller send any other traffic that is ready</p> |
| 23:16      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 15:0       | RW          | 0x0000             | <p>hs_wr_to_cnt</p> <p>This field sets a period for which the DWC_mipi_dsi_host keeps the link inactive after sending a high-speed write operation. This period is measured in cycles of lanebyteclk. The counting starts when the D-PHY enters the Stop state and causes no interrupts</p>                                                                                                                                                                                                                                                                                                                                                                                                 |

**MIPI DSI HOST LP WR TO CNT**

Address: Operational Base + offset (0x0088)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                 |
| 15:0       | RW          | 0x0000             | <p>lp_wr_to_cnt</p> <p>This field sets a period for which the DWC_mipi_dsi_host keeps the link still, after sending a low-power write operation. This period is measured in cycles of lanebyteclk. The counting starts when the D-PHY enters the Stop state and causes no interrupts</p> |

**MIPI DSI HOST BTA TO CNT**

Address: Operational Base + offset (0x008c)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                     |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                        |
| 0    | RW   | 0x0         | <p>bta_to_cnt</p> <p>This field sets a period for which the DWC_mipi_dsi_host keeps the link still, after completing a Bus Turn-Around. This period is measured in cycles of lanebyteclk. The counting starts when the D-PHY enters the Stop state and causes no interrupts</p> |

**MIPI DSI HOST SDF 3D**

Address: Operational Base + offset (0x0090)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                  |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:17 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                     |
| 16    | RW   | 0x0         | <p>send_3d_cfg</p> <p>When set, causes the next VSS packet to include 3D control payload in every VSS packet</p>                                                                                                                                                                             |
| 15:6  | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                     |
| 5     | RW   | 0x0         | <p>right_first</p> <p>This bit defines the left or right order:</p> <p>1'b0: Left eye data is sent first, and then the right eye data is sent.</p> <p>1'b1: Right eye data is sent first, and then the left eye data is sent</p>                                                             |
| 4     | RW   | 0x0         | <p>second_vsync</p> <p>This field defines whether there is a second VSYNC pulse between Left and Right Images, when 3D Image Format is Frame-based:</p> <p>1'b0: No sync pulses between left and right data</p> <p>1'b1: Sync pulse (HSYNC, VSYNC, blanking) between left and right data</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:2        | RW          | 0x0                | <p>format_3d</p> <p>This field defines the 3D image format:</p> <ul style="list-style-type: none"> <li>2'b00: Line (alternating lines of left and right data)</li> <li>2'b01: Frame (alternating frames of left and right data)</li> <li>2'b10: Pixel (alternating pixels of left and right data)</li> <li>2'b11: Reserved</li> </ul> |
| 1:0        | RW          | 0x0                | <p>mode_3d</p> <p>This field defines the 3D mode on/off and display orientation:</p> <ul style="list-style-type: none"> <li>2'b00: 3D mode off (2D mode on)</li> <li>2'b01: 3D mode on, portrait orientation</li> <li>2'b10: 3D mode on, landscape orientation</li> <li>2'b11: Reserved</li> </ul>                                    |

**MIPI DSI HOST LPCLK CTRL**

Address: Operational Base + offset (0x0094)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| 31:2       | RO          | 0x0                | reserved                                                                                                                            |
| 1          | RW          | 0x0                | <p>auto_clklane_ctrl</p> <p>This bit enables the automatic mechanism to stop providing clock in the clock lane when time allows</p> |
| 0          | RW          | 0x0                | <p>phy_txrequestclkhs</p> <p>This bit controls the D-PHY PPI txrequestclkhs signal</p>                                              |

**MIPI DSI HOST PHY TMR LPCLK CFG**

Address: Operational Base + offset (0x0098)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:26      | RO          | 0x0                | reserved                                                                                                                                                                                  |
| 25:16      | RW          | 0x000              | <p>phy_clkhs2lp_time</p> <p>This field configures the maximum time that the D-PHY clock lane takes to go from high-speed to low-power transmission measured in lane byte clock cycles</p> |
| 15:10      | RO          | 0x0                | reserved                                                                                                                                                                                  |
| 9:0        | RW          | 0x000              | <p>phy_clklp2hs_time</p> <p>This field configures the maximum time that the D-PHY clock lane takes to go from low-power to high-speed transmission measured in lane byte clock cycles</p> |

**MIPI DSI HOST PHY TMR CFG**

Address: Operational Base + offset (0x009c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                    |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24      | RW          | 0x00               | <p>phy_hs2lp_time</p> <p>This field configures the maximum time that the D-PHY data lanes take to go from high-speed to low-power transmission measured in lane byte clock cycles</p>                 |
| 23:16      | RW          | 0x00               | <p>phy_lp2hs_time</p> <p>This field configures the maximum time that the D-PHY data lanes take to go from low-power to high-speed transmission measured in lane byte clock cycles</p>                 |
| 15         | RO          | 0x0                | reserved                                                                                                                                                                                              |
| 14:0       | RW          | 0x0000             | <p>max_rd_time</p> <p>This field configures the maximum time required to perform a read command in lane byte clock cycles. This register can only be modified when no read command is in progress</p> |

**MIPI DSI HOST PHY RSTZ**

Address: Operational Base + offset (0x00a0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                    |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4       | RO          | 0x0                | reserved                                                                                                                                              |
| 3          | RW          | 0x0                | <p>phy_forcepll<br/>When the D-PHY is in ULPS, this bit enables the D-PHY PLL.<br/>Dependency: DSI_HOST_FPGA = 0. Otherwise, this bit is reserved</p> |
| 2          | RW          | 0x0                | <p>phy_enableclk<br/>When set to 1, this bit enables the D-PHY Clock Lane module</p>                                                                  |
| 1          | RW          | 0x0                | <p>phy_rstz<br/>When set to 0, this bit places the digital section of the D-PHY in the reset state</p>                                                |
| 0          | RW          | 0x0                | <p>phy_shutdownz<br/>When set to 0, this bit places the D-PHY macro in power-down state</p>                                                           |

**MIPI DSI HOST PHY IF CFG**

Address: Operational Base + offset (0x00a4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                |
| 15:8       | RW          | 0x00               | <p>phy_stop_wait_time<br/>This field configures the minimum wait period to request a high-speed transmission after the Stop state</p>                                                                                                                   |
| 7:2        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                |
| 1:0        | RW          | 0x3                | <p>n_lanes<br/>This field configures the number of active data lanes:<br/>2'b00: One data lane (lane 0)<br/>2'b01: Two data lanes (lanes 0 and 1)<br/>2'b10: Three data lanes (lanes 0, 1, and 2)<br/>2'b11: Four data lanes (lanes 0, 1, 2, and 3)</p> |

**MIPI DSI HOST PHY STATUS**

Address: Operational Base + offset (0x00b0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------|
| 31:13      | RO          | 0x0                | reserved                                                                                    |
| 12         | RO          | 0x0                | phy_ulpssactivenot3lane<br>This bit indicates the status of ulpsactivenot3lane D-PHY signal |
| 11         | RO          | 0x0                | phy_stopstate3lane<br>This bit indicates the status of phystopstate3lane D-PHY signal       |
| 10         | RO          | 0x0                | phy_ulpssactivenot2lane<br>This bit indicates the status of ulpsactivenot2lane D-PHY signal |
| 9          | RO          | 0x0                | phy_stopstate2lane<br>This bit indicates the status of phystopstate2lane D-PHY signal       |
| 8          | RO          | 0x0                | phy_ulpssactivenot1lane<br>This bit indicates the status of ulpsactivenot1lane D-PHY signal |
| 7          | RO          | 0x0                | phy_stopstate1lane<br>This bit indicates the status of phystopstate1lane D-PHY signal       |
| 6          | RO          | 0x0                | phy_rxulpssesc0lane<br>This bit indicates the status of rxulpssesc0lane D-PHY signal        |
| 5          | RO          | 0x0                | phy_ulpssactivenot0lane<br>This bit indicates the status of ulpsactivenot0lane D-PHY signal |
| 4          | RO          | 0x0                | phy_stopstate0lane<br>This bit indicates the status of phystopstate0lane D-PHY signal       |
| 3          | RO          | 0x0                | phy_ulpssactivenotclk<br>This bit indicates the status of phyulpssactivenotclk D-PHY signal |
| 2          | RO          | 0x0                | phy_stopstateclklane<br>This bit indicates the status of phystopstateclklane D-PHY signal   |
| 1          | RO          | 0x0                | phy_direction<br>This bit indicates the status of phydirection D-PHY signal                 |
| 0          | RO          | 0x0                | phy_lock<br>This bit indicates the status of phylock D-PHY signal                           |

**MIPI DSI HOST INT ST0**

Address: Operational Base + offset (0x00bc)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------|
| 31:21      | RO          | 0x0                | reserved                                                                                                     |
| 20         | RO          | 0x0                | dphy_errors_4<br>This bit indicates the LP1 contention error ErrContentionLP1 from Lane 0                    |
| 19         | RW          | 0x0                | dphy_errors_3<br>This bit indicates the LP0 contention error ErrContentionLP0 from Lane 0                    |
| 18         | RO          | 0x0                | dphy_errors_2<br>This bit indicates the ErrControl error from Lane 0                                         |
| 17         | RO          | 0x0                | dphy_errors_1<br>This bit indicates ErrSyncEsc low-power data transmission synchronization error from Lane 0 |
| 16         | RO          | 0x0                | dphy_errors_0<br>This bit indicates ErrEsc escape entry error from Lane 0                                    |
| 15         | RO          | 0x0                | ack_with_err_15<br>This bit retrieves the DSI protocol violation from the Acknowledge error report           |
| 14         | RO          | 0x0                | ack_with_err_14<br>This bit retrieves the reserved (specific to device) from the Acknowledge error report    |
| 13         | RO          | 0x0                | ack_with_err_13<br>This bit retrieves the invalid transmission length from the Acknowledge error report      |
| 12         | RO          | 0x0                | ack_with_err_12<br>This bit retrieves the DSI VC ID Invalid from the Acknowledge error report                |
| 11         | RO          | 0x0                | ack_with_err_11<br>This bit retrieves the not recognized DSI data type from the Acknowledge error report     |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------|
| 10         | RO          | 0x0                | ack_with_err_10<br>This bit retrieves the checksum error (long packet only) from the Acknowledge error report      |
| 9          | RO          | 0x0                | ack_with_err_9<br>This bit retrieves the ECC error, multi-bit (detected, not corrected) from the Acknowledge error |
| 8          | RO          | 0x0                | ack_with_err_8<br>This bit retrieves the ECC error, single-bit (detected and corrected) from the Acknowledge error |
| 7          | RO          | 0x0                | ack_with_err_7<br>This bit retrieves the reserved (specific to device) from the Acknowledge error report           |
| 6          | RO          | 0x0                | ack_with_err_6<br>This bit retrieves the False Control error from the Acknowledge error report                     |
| 5          | RO          | 0x0                | ack_with_err_5<br>This bit retrieves the Peripheral Timeout error from the Acknowledge Error report                |
| 4          | RO          | 0x0                | ack_with_err_4<br>This bit retrieves the LP Transmit Sync error from the Acknowledge error report                  |
| 3          | RO          | 0x0                | ack_with_err_3<br>This bit retrieves the Escape Mode Entry Command error from the Acknowledge error report         |
| 2          | RO          | 0x0                | ack_with_err_2<br>This bit retrieves the EoT Sync error from the Acknowledge error report                          |
| 1          | RO          | 0x0                | ack_with_err_1<br>This bit retrieves the SoT Sync error from the Acknowledge error report                          |
| 0          | RO          | 0x0                | ack_with_err_0<br>This bit retrieves the SoT error from the Acknowledge error report                               |

**MIPI DSI HOST INT ST1**

Address: Operational Base + offset (0x00c0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:18      | RO          | 0x0                | reserved                                                                                                                                                                                |
| 17         | RW          | 0x0                | <p>dbi_illegal_comm_err</p> <p>This bit indicates that an attempt to write an illegal command on the DBI interface is made and the core is blocked by transmission</p>                  |
| 16         | RO          | 0x0                | <p>dbi_pld_recv_err</p> <p>This bit indicates that during a DBI read back packet, the payload FIFO becomes full and the received data is corrupted</p>                                  |
| 15         | RO          | 0x0                | <p>dbi_pld_rd_err</p> <p>This bit indicates that during a DCS read data, the payload FIFO goes empty and the data sent to the interface is corrupted</p>                                |
| 14         | RO          | 0x0                | <p>dbi_pld_wr_err</p> <p>This bit indicates that the system tried to write the payload data through the DBI interface and the FIFO is full. Therefore, the command is not written</p>   |
| 13         | RO          | 0x0                | <p>dbi_cmd_wr_err</p> <p>This bit indicates that the system tried to write a command through the DBI but the command FIFO is full. Therefore, the command is not written</p>            |
| 12         | RO          | 0x0                | <p>gen_pld_recev_err</p> <p>This bit indicates that during a generic interface packet read back, the payload FIFO becomes full and the received data is corrupted</p>                   |
| 11         | RO          | 0x0                | <p>gen_pld_rd_err</p> <p>This bit indicates that during a DCS read data, the payload FIFO becomes empty and the data sent to the interface is corrupted</p>                             |
| 10         | RO          | 0x0                | <p>gen_pld_send_err</p> <p>This bit indicates that during a Generic interface packet build, the payload FIFO becomes empty and corrupt data is sent</p>                                 |
| 9          | RO          | 0x0                | <p>gen_pld_wr_err</p> <p>This bit indicates that the system tried to write a payload data through the Generic interface and the FIFO is full. Therefore, the payload is not written</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8          | RO          | 0x0                | gen_cmd_wr_err<br>This bit indicates that the system tried to write a command through the Generic interface and the FIFO is full. Therefore, the command is not written |
| 7          | RO          | 0x0                | dpi_pld_wr_err<br>This bit indicates that during a DPI pixel line storage, the payload FIFO becomes full and the data stored is corrupted                               |
| 6          | RO          | 0x0                | eopt_err<br>This bit indicates that the EoTp packet is not received at the end of the incoming peripheral transmission                                                  |
| 5          | RO          | 0x0                | pkt_size_err<br>This bit indicates that the packet size error is detected during the packet reception                                                                   |
| 4          | RO          | 0x0                | crc_err<br>This bit indicates that the CRC error is detected in the received packet payload                                                                             |
| 3          | RO          | 0x0                | ecc_multi_err<br>This bit indicates that the ECC multiple error is detected in a received packet                                                                        |
| 2          | RO          | 0x0                | ecc_single_err<br>This bit indicates that the ECC single error is detected and corrected in a received packet                                                           |
| 1          | RO          | 0x0                | to_lp_rx<br>This bit indicates that the low-power reception timeout counter reached the end and contention is detected                                                  |
| 0          | RO          | 0x0                | to_hs_tx<br>This bit indicates that the high-speed transmission timeout counter reached the end and contention is detected                                              |

**MIPI DSI HOST INT MSK0**

Address: Operational Base + offset (0x00c4)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------|
| 20         | RW          | 0x0                | dphy_errors_4<br>This bit indicates the LP1 contention error ErrContentionLP1 from Lane 0                     |
| 19         | RW          | 0x0                | dphy_errors_3<br>This bit indicates the LP0 contention error ErrContentionLP0 from Lane 0                     |
| 18         | RW          | 0x0                | dphy_errors_2<br>This bit indicates the ErrControl error from Lane 0                                          |
| 17         | RW          | 0x0                | dphy_errors_1<br>This bit indicates ErrSyncEsc low-power data transmission synchronization error from Lane 0  |
| 16         | RW          | 0x0                | dphy_errors_0<br>This bit indicates ErrEsc escape entry error from Lane 0                                     |
| 15         | RW          | 0x0                | ack_with_err_15<br>This bit retrieves the DSI protocol violation from the Acknowledge error report            |
| 14         | RW          | 0x0                | ack_with_err_14<br>This bit retrieves the reserved (specific to device) from the Acknowledge error report     |
| 13         | RW          | 0x0                | ack_with_err_13<br>This bit retrieves the invalid transmission length from the Acknowledge error report       |
| 12         | RW          | 0x0                | ack_with_err_12<br>This bit retrieves the DSI VC ID Invalid from the Acknowledge error report                 |
| 11         | RW          | 0x0                | ack_with_err_11<br>This bit retrieves the not recognized DSI data type from the Acknowledge error report      |
| 10         | RW          | 0x0                | ack_with_err_10<br>This bit retrieves the checksum error (long packet only) from the Acknowledge error report |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------|
| 9          | RW          | 0x0                | ack_with_err_9<br>This bit retrieves the ECC error, multi-bit (detected, not corrected) from the Acknowledge error |
| 8          | RW          | 0x0                | ack_with_err_8<br>This bit retrieves the ECC error, single-bit (detected and corrected) from the Acknowledge error |
| 7          | RW          | 0x0                | ack_with_err_7<br>This bit retrieves the reserved (specific to device) from the Acknowledge error report           |
| 6          | RW          | 0x0                | ack_with_err_6<br>This bit retrieves the False Control error from the Acknowledge error report                     |
| 5          | RW          | 0x0                | ack_with_err_5<br>This bit retrieves the Peripheral Timeout error from the Acknowledge Error report                |
| 4          | RW          | 0x0                | ack_with_err_4<br>This bit retrieves the LP Transmit Sync error from the Acknowledge error report                  |
| 3          | RW          | 0x0                | ack_with_err_3<br>This bit retrieves the Escape Mode Entry Command error from the Acknowledge error report         |
| 2          | RW          | 0x0                | ack_with_err_2<br>This bit retrieves the EoT Sync error from the Acknowledge error report                          |
| 1          | RW          | 0x0                | ack_with_err_1<br>This bit retrieves the SoT Sync error from the Acknowledge error report                          |
| 0          | RW          | 0x0                | ack_with_err_0<br>This bit retrieves the SoT error from the Acknowledge error report                               |

**MIPI\_DSI\_HOST\_INT\_MSK1**

Address: Operational Base + offset (0x00c8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:18      | RO          | 0x0                | reserved                                                                                                                                                                                |
| 17         | RW          | 0x0                | <p>dbi_illegal_comm_err</p> <p>This bit indicates that an attempt to write an illegal command on the DBI interface is made and the core is blocked by transmission</p>                  |
| 16         | RW          | 0x0                | <p>dbi_pld_recv_err</p> <p>This bit indicates that during a DBI read back packet, the payload FIFO becomes full and the received data is corrupted</p>                                  |
| 15         | RW          | 0x0                | <p>dbi_pld_rd_err</p> <p>This bit indicates that during a DCS read data, the payload FIFO goes empty and the data sent to the interface is corrupted</p>                                |
| 14         | RW          | 0x0                | <p>dbi_pld_wr_err</p> <p>This bit indicates that the system tried to write the payload data through the DBI interface and the FIFO is full. Therefore, the command is not written</p>   |
| 13         | RW          | 0x0                | <p>dbi_cmd_wr_err</p> <p>This bit indicates that the system tried to write a command through the DBI but the command FIFO is full. Therefore, the command is not written</p>            |
| 12         | RW          | 0x0                | <p>gen_pld_recev_err</p> <p>This bit indicates that during a generic interface packet read back, the payload FIFO becomes full and the received data is corrupted</p>                   |
| 11         | RW          | 0x0                | <p>gen_pld_rd_err</p> <p>This bit indicates that during a DCS read data, the payload FIFO becomes empty and the data sent to the interface is corrupted</p>                             |
| 10         | RW          | 0x0                | <p>gen_pld_send_err</p> <p>This bit indicates that during a Generic interface packet build, the payload FIFO becomes empty and corrupt data is sent</p>                                 |
| 9          | RW          | 0x0                | <p>gen_pld_wr_err</p> <p>This bit indicates that the system tried to write a payload data through the Generic interface and the FIFO is full. Therefore, the payload is not written</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8          | RW          | 0x0                | gen_cmd_wr_err<br>This bit indicates that the system tried to write a command through the Generic interface and the FIFO is full. Therefore, the command is not written |
| 7          | RW          | 0x0                | dpi_pld_wr_err<br>This bit indicates that during a DPI pixel line storage, the payload FIFO becomes full and the data stored is corrupted                               |
| 6          | RW          | 0x0                | eopt_err<br>This bit indicates that the EoTp packet is not received at the end of the incoming peripheral transmission                                                  |
| 5          | RW          | 0x0                | pkt_size_err<br>This bit indicates that the packet size error is detected during the packet reception                                                                   |
| 4          | RW          | 0x0                | crc_err<br>This bit indicates that the CRC error is detected in the received packet payload                                                                             |
| 3          | RW          | 0x0                | ecc_multi_err<br>This bit indicates that the ECC multiple error is detected in a received packet                                                                        |
| 2          | RW          | 0x0                | ecc_single_err<br>This bit indicates that the ECC single error is detected and corrected in a received packet                                                           |
| 1          | RW          | 0x0                | to_lp_rx<br>This bit indicates that the low-power reception timeout counter reached the end and contention is detected                                                  |
| 0          | RW          | 0x0                | to_hs_tx<br>This bit indicates that the high-speed transmission timeout counter reached the end and contention is detected                                              |

**MIPI DSI HOST INT FORCE0**

Address: Operational Base + offset (0x00d8)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------|
| 20         | RW          | 0x0                | dphy_errors_4<br>This bit indicates the LP1 contention error ErrContentionLP1 from Lane 0                     |
| 19         | RW          | 0x0                | dphy_errors_3<br>This bit indicates the LP0 contention error ErrContentionLP0 from Lane 0                     |
| 18         | RW          | 0x0                | dphy_errors_2<br>This bit indicates the ErrControl error from Lane 0                                          |
| 17         | RW          | 0x0                | dphy_errors_1<br>This bit indicates ErrSyncEsc low-power data transmission synchronization error from Lane 0  |
| 16         | RW          | 0x0                | dphy_errors_0<br>This bit indicates ErrEsc escape entry error from Lane 0                                     |
| 15         | RW          | 0x0                | ack_with_err_15<br>This bit retrieves the DSI protocol violation from the Acknowledge error report            |
| 14         | RW          | 0x0                | ack_with_err_14<br>This bit retrieves the reserved (specific to device) from the Acknowledge error report     |
| 13         | RW          | 0x0                | ack_with_err_13<br>This bit retrieves the invalid transmission length from the Acknowledge error report       |
| 12         | RW          | 0x0                | ack_with_err_12<br>This bit retrieves the DSI VC ID Invalid from the Acknowledge error report                 |
| 11         | RW          | 0x0                | ack_with_err_11<br>This bit retrieves the not recognized DSI data type from the Acknowledge error report      |
| 10         | RW          | 0x0                | ack_with_err_10<br>This bit retrieves the checksum error (long packet only) from the Acknowledge error report |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------|
| 9          | RW          | 0x0                | ack_with_err_9<br>This bit retrieves the ECC error, multi-bit (detected, not corrected) from the Acknowledge error |
| 8          | RW          | 0x0                | ack_with_err_8<br>This bit retrieves the ECC error, single-bit (detected and corrected) from the Acknowledge error |
| 7          | RW          | 0x0                | ack_with_err_7<br>This bit retrieves the reserved (specific to device) from the Acknowledge error report           |
| 6          | RW          | 0x0                | ack_with_err_6<br>This bit retrieves the False Control error from the Acknowledge error report                     |
| 5          | RW          | 0x0                | ack_with_err_5<br>This bit retrieves the Peripheral Timeout error from the Acknowledge Error report                |
| 4          | RW          | 0x0                | ack_with_err_4<br>This bit retrieves the LP Transmit Sync error from the Acknowledge error report                  |
| 3          | RW          | 0x0                | ack_with_err_3<br>This bit retrieves the Escape Mode Entry Command error from the Acknowledge error report         |
| 2          | RW          | 0x0                | ack_with_err_2<br>This bit retrieves the EoT Sync error from the Acknowledge error report                          |
| 1          | RW          | 0x0                | ack_with_err_1<br>This bit retrieves the SoT Sync error from the Acknowledge error report                          |
| 0          | RW          | 0x0                | ack_with_err_0<br>This bit retrieves the SoT error from the Acknowledge error report                               |

**MIPI DSI HOST INT FORCE1**

Address: Operational Base + offset (0x00dc)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:18      | RO          | 0x0                | reserved                                                                                                                                                                                |
| 17         | RW          | 0x0                | <p>dbi_illegal_comm_err</p> <p>This bit indicates that an attempt to write an illegal command on the DBI interface is made and the core is blocked by transmission</p>                  |
| 16         | RW          | 0x0                | <p>dbi_pld_recv_err</p> <p>This bit indicates that during a DBI read back packet, the payload FIFO becomes full and the received data is corrupted</p>                                  |
| 15         | RW          | 0x0                | <p>dbi_pld_rd_err</p> <p>This bit indicates that during a DCS read data, the payload FIFO goes empty and the data sent to the interface is corrupted</p>                                |
| 14         | RW          | 0x0                | <p>dbi_pld_wr_err</p> <p>This bit indicates that the system tried to write the payload data through the DBI interface and the FIFO is full. Therefore, the command is not written</p>   |
| 13         | RW          | 0x0                | <p>dbi_cmd_wr_err</p> <p>This bit indicates that the system tried to write a command through the DBI but the command FIFO is full. Therefore, the command is not written</p>            |
| 12         | RW          | 0x0                | <p>gen_pld_recev_err</p> <p>This bit indicates that during a generic interface packet read back, the payload FIFO becomes full and the received data is corrupted</p>                   |
| 11         | RW          | 0x0                | <p>gen_pld_rd_err</p> <p>This bit indicates that during a DCS read data, the payload FIFO becomes empty and the data sent to the interface is corrupted</p>                             |
| 10         | RW          | 0x0                | <p>gen_pld_send_err</p> <p>This bit indicates that during a Generic interface packet build, the payload FIFO becomes empty and corrupt data is sent</p>                                 |
| 9          | RW          | 0x0                | <p>gen_pld_wr_err</p> <p>This bit indicates that the system tried to write a payload data through the Generic interface and the FIFO is full. Therefore, the payload is not written</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8          | RW          | 0x0                | gen_cmd_wr_err<br>This bit indicates that the system tried to write a command through the Generic interface and the FIFO is full. Therefore, the command is not written |
| 7          | RW          | 0x0                | dpi_pld_wr_err<br>This bit indicates that during a DPI pixel line storage, the payload FIFO becomes full and the data stored is corrupted                               |
| 6          | RW          | 0x0                | eopt_err<br>This bit indicates that the EoTp packet is not received at the end of the incoming peripheral transmission                                                  |
| 5          | RW          | 0x0                | pkt_size_err<br>This bit indicates that the packet size error is detected during the packet reception                                                                   |
| 4          | RW          | 0x0                | crc_err<br>This bit indicates that the CRC error is detected in the received packet payload                                                                             |
| 3          | RW          | 0x0                | ecc_multi_err<br>This bit indicates that the ECC multiple error is detected in a received packet                                                                        |
| 2          | RW          | 0x0                | ecc_single_err<br>This bit indicates that the ECC single error is detected and corrected in a received packet                                                           |
| 1          | RW          | 0x0                | to_lp_rx<br>This bit indicates that the low-power reception timeout counter reached the end and contention is detected                                                  |
| 0          | RW          | 0x0                | to_hs_tx<br>This bit indicates that the high-speed transmission timeout counter reached the end and contention is detected                                              |

**MIPI DSI HOST VID SHADOW CTRL**

Address: Operational Base + offset (0x0100)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:17      | RO          | 0x0                | reserved                                                                                                                                                                                                                 |
| 16         | RW          | 0x0                | <p>vid_shadow_pin_req</p> <p>When set to 1, the video request is done by external pin. In this mode,<br/>vid_shadow_req is ignored</p>                                                                                   |
| 15:9       | RO          | 0x0                | reserved                                                                                                                                                                                                                 |
| 8          | RW          | 0x0                | <p>vid_shadow_req</p> <p>When set to 1, the DPI registers are copied to the auxiliary registers.</p> <p>After copying, this bit is auto cleared</p>                                                                      |
| 7:1        | RO          | 0x0                | reserved                                                                                                                                                                                                                 |
| 0          | RW          | 0x0                | <p>vid_shadow_en</p> <p>When set to 1, DPI receives the active configuration from the auxiliary registers. When this bit is set along with the vid_shadow_req bit, the auxiliary registers are automatically updated</p> |

**MIPI DSI HOST DPI VCID ACT**

Address: Operational Base + offset (0x010c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------|
| 31:2       | RO          | 0x0                | reserved                                                                                                           |
| 1:0        | RW          | 0x0                | <p>dpi_vcidx</p> <p>This field configures the DPI virtual channel id that is indexed to the Video mode packets</p> |

**MIPI DSI HOST DPI COLOR CODING ACT**

Address: Operational Base + offset (0x0110)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:9       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 8          | RW          | 0x0                | loosely18_en<br>When set to 1, this bit activates loosely packed variant to 18-bit configurations                                                                                                                                                                                                                                                                                                                              |
| 7:4        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 3:0        | RW          | 0x0                | dpi_color_coding<br>This field configures the DPI color coding as follows:<br>0000: 16-bit configuration 1<br>0001: 16-bit configuration 2<br>0010: 16-bit configuration 3<br>0011: 18-bit configuration 1<br>0100: 18-bit configuration 2<br>0101: 24-bit<br>0110: 20-bit YCbCr 4:2:2 loosely packed<br>0111: 24-bit YCbCr 4:2:2<br>1000: 16-bit YCbCr 4:2:2<br>1001: 30-bit<br>1010: 36-bit<br>1011-1111: 12-bit YCbCr 4:2:0 |

**MIPI DSI HOST DPI LP CMD TIM ACT**

Address: Operational Base + offset (0x0118)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24      | RO          | 0x0                | reserved                                                                                                                                                                                                      |
| 23:16      | RO          | 0x00               | outvact_lpcmd_time<br>This field is used for the transmission of commands in low-power mode. It defines the size, in bytes, of the largest packet that can fit in a line during the VSA, VBP, and VFP regions |
| 15:8       | RO          | 0x0                | reserved                                                                                                                                                                                                      |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                        |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0        | RO          | 0x00               | <p>invact_lpcmd_time</p> <p>This field is used for the transmission of commands in low-power mode. It defines the size, in bytes, of the largest packet that can fit in a line during the VACT region</p> |

**MIPI DSI HOST VID MODE CFG ACT**

Address: Operational Base + offset (0x0138)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:25      | RO          | 0x0                | reserved                                                                                                                                          |
| 24         | RW          | 0x0                | <p>vpg_orientation</p> <p>This field indicates the color bar orientation as follows:</p> <p>0: Vertical mode</p> <p>1: Horizontal mode</p>        |
| 23:21      | RO          | 0x0                | reserved                                                                                                                                          |
| 20         | RO          | 0x0                | <p>vpg_mode</p> <p>This field is to select the pattern:</p> <p>0: Color bar (horizontal or vertical)</p> <p>1: BER pattern (vertical only)</p>    |
| 19:17      | RO          | 0x0                | reserved                                                                                                                                          |
| 16         | RO          | 0x0                | <p>vpg_en</p> <p>When set to 1, this bit enables the video mode pattern generator</p>                                                             |
| 15         | RO          | 0x0                | <p>lp_cmd_en</p> <p>When set to 1, this bit enables the command transmission only in lowpower mode</p>                                            |
| 14         | RO          | 0x0                | <p>frame_bta_ack_en</p> <p>When set to 1, this bit enables the request for an acknowledge response at the end of a frame</p>                      |
| 13         | RO          | 0x0                | <p>lp_hfp_en</p> <p>When set to 1, this bit enables the return to low-power inside the Horizontal Front Porch (HFP) period when timing allows</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12         | RO          | 0x0                | lp_hbp_en<br>When set to 1, this bit enables the return to low-power inside the Horizontal Back Porch (HBP) period when timing allows                                                       |
| 11         | RO          | 0x0                | lp_vact_en<br>When set to 1, this bit enables the return to low-power inside the Vertical Active (VACT) period when timing allows                                                           |
| 10         | RO          | 0x0                | lp_vfp_en<br>When set to 1, this bit enables the return to low-power inside the Vertical Front Porch (VFP) period when timing allows                                                        |
| 9          | RO          | 0x0                | lp_vbp_en<br>When set to 1, this bit enables the return to low-power inside the Vertical Back Porch (VBP) period when timing allows                                                         |
| 8          | RO          | 0x0                | lp_vsa_en<br>When set to 1, this bit enables the return to low-power inside the Vertical Sync Time (VSA) period when timing allows                                                          |
| 7:2        | RO          | 0x0                | reserved                                                                                                                                                                                    |
| 1:0        | RO          | 0x0                | vid_mode_type<br>This field indicates the video mode transmission type as follows:<br>2'b00: Non-burst with sync pulses<br>2'b01: Non-burst with sync events<br>2'b10 and 2'b11: Burst mode |

**MIPI DSI HOST VID PKT SIZE ACT**

Address: Operational Base + offset (0x013c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                            |
| 13:0       | RO          | 0x0000             | <p>vid_pkt_size<br/>This field configures the number of pixels in a single video packet. For 18-bit not loosely packed data types, this number must be a multiple of 4. For YCbCr data types, it must be a multiple of 2, as described in the DSI specification</p> |

**MIPI DSI HOST VID NUM CHUNKS ACT**

Address: Operational Base + offset (0x0140)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:13      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                    |
| 12:0       | RO          | 0x0000             | <p>vid_num_chunks<br/>This register configures the number of chunks to be transmitted during a Line period (a chunk consists of a video packet and a null packet). If set to 0 or 1, the video line is transmitted in a single packet. If set to 1, the packet is part of a chunk, so a null packet follows it if vid_null_size &gt; 0. Otherwise, multiple chunks are used to transmit each video line</p> |

**MIPI DSI HOST VID NULL SIZE ACT**

Address: Operational Base + offset (0x0144)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------|
| 31:13      | RO          | 0x0                | reserved                                                                                                                              |
| 12:0       | RW          | 0x0000             | <p>vid_null_size<br/>This register configures the number of bytes inside a null packet. Setting it to 0 disables the null packets</p> |

**MIPI DSI HOST VID HSA TIME ACT**

Address: Operational Base + offset (0x0148)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------|
| 31:12      | RO          | 0x0                | reserved                                                                                                    |
| 11:0       | RO          | 0x000              | vid_hsa_time<br>This field configures the Horizontal Synchronism Active period in lane<br>byte clock cycles |

**MIPI DSI HOST VID HBP TIME ACT**

Address: Operational Base + offset (0x014c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------|
| 31:12      | RO          | 0x0                | reserved                                                                                                    |
| 11:0       | RW          | 0x000              | vid_hsa_time<br>This field configures the Horizontal Synchronism Active period in lane<br>byte clock cycles |

**MIPI DSI HOST VID HLINE TIME ACT**

Address: Operational Base + offset (0x0150)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------|
| 31:15      | RO          | 0x0                | reserved                                                                                                                        |
| 14:0       | RO          | 0x0000             | vid_hline_time<br>This field configures the size of the total line time<br>(HSA+HBP+HACT+HFP) counted in lane byte clock cycles |

**MIPI DSI HOST VID VSA LINES ACT**

Address: Operational Base + offset (0x0154)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------|
| 31:10      | RO          | 0x0                | reserved                                                                                                            |
| 9:0        | RO          | 0x000              | vsa_lines<br>This field configures the Vertical Synchronism Active period measured<br>in number of horizontal lines |

**MIPI DSI HOST VID VBP LINES ACT**

Address: Operational Base + offset (0x0158)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                       |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------|
| 31:10      | RO          | 0x0                | reserved                                                                                                 |
| 9:0        | RW          | 0x000              | vbp_lines<br>This field configures the Vertical Back Porch period measured in number of horizontal lines |

**MIPI DSI HOST VID VFP LINES ACT**

Address: Operational Base + offset (0x015c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                        |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x0                | reserved                                                                                                  |
| 0          | RO          | 0x0                | vfp_lines<br>This field configures the Vertical Front Porch period measured in number of horizontal lines |

**MIPI DSI HOST VID VACTIVE LINES ACT**

Address: Operational Base + offset (0x0160)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                        |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------|
| 31:14      | RO          | 0x0                | reserved                                                                                                  |
| 13:0       | RO          | 0x0000             | v_active_lines<br>This field configures the Vertical Active period measured in number of horizontal lines |

**MIPI DSI HOST SDF 3D ACT**

Address: Operational Base + offset (0x0190)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                       |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------|
| 31:17      | RO          | 0x0                | reserved                                                                                                 |
| 16         | RW          | 0x0                | send_3d_cfg<br>When set, causes the next VSS packet to include 3D control payload<br>in every VSS packet |
| 15:6       | RO          | 0x0                | reserved                                                                                                 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5          | RO          | 0x0                | <p>right_first</p> <p>This bit defines the left or right order:</p> <p>1'b0: Left eye data is sent first, and then the right eye data is sent.</p> <p>1'b1: Right eye data is sent first, and then the left eye data is sent</p>                                                             |
| 4          | RO          | 0x0                | <p>second_vsync</p> <p>This field defines whether there is a second VSYNC pulse between Left and Right Images, when 3D Image Format is Frame-based:</p> <p>1'b0: No sync pulses between left and right data</p> <p>1'b1: Sync pulse (HSYNC, VSYNC, blanking) between left and right data</p> |
| 3:2        | RO          | 0x0                | <p>format_3d</p> <p>This field defines the 3D image format:</p> <p>2'b00: Line (alternating lines of left and right data)</p> <p>2'b01: Frame (alternating frames of left and right data)</p> <p>2'b10: Pixel (alternating pixels of left and right data)</p> <p>2'b11: Reserved</p>         |
| 1:0        | RO          | 0x0                | <p>mode_3d</p> <p>This field defines the 3D mode on/off and display orientation:</p> <p>2'b00: 3D mode off (2D mode on)</p> <p>2'b01: 3D mode on, portrait orientation</p> <p>2'b10: 3D mode on, landscape orientation</p> <p>2'b11: Reserved</p>                                            |

## Chapter 13 MIPI DSI D-PHY

### 13.1 Overview

The MIPI D-PHY integrates a MIPI® V1.0 compatible PHY that supports up to 1.0Gbps high speed data receiver, plus a MIPI® low-power low speed transceiver that supports data transfer in the bi-directional mode. The IP supports the full specifications described in V1.0 of the D-PHY spec. The D-PHY is built in with a standard digital interface to talk to any third party Host controller. The architecture supports connection of multiple data lanes in parallel – up to 4 data lanes can be connected to increase the total through-put, customizable to user determined configurations. The I/O and ESD are also built-in as one in a rectangular footprint for any configuration (one lane to 4 lanes or more). It is optimized for high speed applications with robust timing and small silicon area. The D-PHY supports the electrical portion of MIPI D-PHY V1.0 standard, covering all transmission modes (ULP/LP/HS).The MIPI D-PHY cost-effectively adds MIPI D-PHY V1.0 capability to any SOC used in communication and consumer electronics field.

The MIPI D-PHY supports the following features:

- Mixed-signal D-PHY mixed-signal hard-macro- HS/LS Transmitter and LS/HS Receiver solution
- Designed to MIPI® v1.0 Specifications
- Integrated PHY Protocol Interface (PPI) supports interface to CSI, DSI and UniPro™
- MIPI® protocols
- 1.0Gbps maximum data transfer rate per lane
- Expandable to support 4 data lanes, providing up to 4.0Gbps transfer rate
- MIPI-HS, MIPI-LP , LVDS, TTL modes supported
- 10Mbps per lane in low-power mode
- Unidirectional and bi-directional modes supported
- Automatic termination control for HS and LP modes
- Low-Power dissipation: less than 3mA/Lane in HS TX/RX mode
- Tx/Rx Buffers with tunable On-Die-Termination and advanced equalization.
- Embedded ESD, boundary scan support logic.

### 13.2 Block Diagram



Fig. 13-1 MIPI DSI D-PHY detailed block diagram

MIPI D-PHY configuration contains one Clock Lane Module and four Data Lane Modules. Each of these PHY Lane Modules communicates via two Lines to a complementary part at the other side of the Lane Interconnect. Figure 1 shows the DPHY architecture.

## 13.3 Function Description

### 13.3.1 System Connection

The MIPI DS1 DPHY supports MIPI/LVDS/TTL mode. VOP outputs data use different ports for MIPI and LVDS mode. The connection with VOP of three mode shows in following figure:



Fig. 13-2 MIPI DS1 D-PHY and VOP connection

Note: The other selects and detail information of TTL signals is illustrated in chapter configuration for TTL MODE.

### 13.3.2 MIPI MODE

In MIPI mode, there are some functions of DPHY controlled by grf registers. These register bit and function is show in following table:

Table 13-1 function of grf bits in MIPI mode

| register bit                    | function                                                                                                                                                                    |
|---------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| grf_con_dsi_phy_lane0_frctxstpm | Force Lane Module Into Transmit mode / Generate Stop state. This signal allows the protocol to force a Lane Module into transmit mode and Stop state during initialization. |
| grf_con_dsi_phy_lane1_frctxstpm | Force Lane Module Into Transmit mode / Generate Stop state. This signal allows the protocol to force a Lane Module into transmit mode and Stop state during initialization. |
| grf_con_dsi_phy_lane2_frctxstpm | Force Lane Module Into Transmit mode / Generate Stop state. This signal allows the protocol to force a Lane Module into transmit mode and Stop state during initialization. |
| grf_con_dsi_phy_lane3_frctxstpm | Force Lane Module Into Transmit mode / Generate Stop state. This signal allows the protocol to force a Lane Module into transmit mode and Stop state during initialization. |

| register bit                      | function                                                                                                                                                                          |
|-----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| grf_con_dsi_phy_lane0_turndisable | Disable Turn-around. This signal is used to prevent a (bi-directional) Lane from going into transmit mode – even if it observes a turn-around request on the Lane interconnect.   |
| grf_con_dsi_phy_forcerxmode       | Force Lane Module Into Receive mode / Wait for Stop state. This signal allows the protocol to initialize a Lane Module, or force a bi-directional Lane Module, into receive mode. |

### 13.3.3 Program PLL in MIPI mode

Frequency Calculating Formula

The PLL output frequency can be calculated using a simple formula:

$$\text{PLL\_Output\_Frequency} = (\text{FREF}/\text{PREDIV} * \text{FBDIV})/2$$

PLL\_Output\_Frequency: It is equal to DDR\_Clock\_Frequency \* 2

FREF: 24 Mhz

PREDIV: PLL input reference clock divider which can be configured by the register of prediv

FBDIV: Integer value programmed into feedback divider which can be configured by the register of fbdv

Additional Programming Considerations

1. The divided reference frequency (FREF/PREDIV) should be less than 40MHz.
2. The all possible settings of feedback divider are 12, 13, 14, 16~511.

### 13.3.4 LVDS MODE

After video data is sent from VOP, it first goes into lvds\_format block. Lvds\_format block first maps video data to 4 types as show in Table 13-2 LVDS map setting. This function is controlled by register grf\_con\_lvds\_select[1:0]. After video data map, you can use grf\_con\_lvds\_msbsel to revert data bits into MSB.

Table 13-2 LVDS map setting

|                             |                                                                                                                                                                                                                                                                                          |
|-----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| grf_co<br>n_lvds<br>_select | LVDS map when (grf_con_lvds_msbsel == 0)<br>lvds_lane1 use IO_MIPI_DSI_DATANO and IO_MIPI_DSI_DATAP0<br>lvds_lane2 use IO_MIPI_DSI_DATAN1 and IO_MIPI_DSI_DATAP1<br>lvds_lane3 use IO_MIPI_DSI_DATAN2 and IO_MIPI_DSI_DATAP2<br>lvds_lane4 use IO_MIPI_DSI_DATAN3 and IO_MIPI_DSI_DATAP3 |
| 0                           | lvds_lane1      {g_data[0],r_data[5:0]}                                                                                                                                                                                                                                                  |
|                             | lvds_lane2      {b_data[1:0],g_data[5:1]}                                                                                                                                                                                                                                                |
|                             | lvds_lane3      {lcdc_den, lcdc_vsyncn, lcdc_hsyncn, b_data[5:2]}                                                                                                                                                                                                                        |
|                             | lvds_lane4      {1'b0,b_data[7:6],g_data[7:6],r_data[7:6]}                                                                                                                                                                                                                               |
| 1                           | lvds_lane1      {g_data[2],r_data[7:2]}                                                                                                                                                                                                                                                  |
|                             | lvds_lane2      {b_data[3:2],g_data[7:3]}                                                                                                                                                                                                                                                |
|                             | lvds_lane3      {lcdc_den, lcdc_vsyncn, lcdc_hsyncn, b_data[7:4]}                                                                                                                                                                                                                        |
|                             | lvds_lane4      {1'b0,b_data[1:0],g_data[1:0],r_data[1:0]}                                                                                                                                                                                                                               |
| 2                           | lvds_lane1      {g_data[2],r_data[7:2]}                                                                                                                                                                                                                                                  |
|                             | lvds_lane2      {b_data[3:2],g_data[7:3]}                                                                                                                                                                                                                                                |
|                             | lvds_lane3      {lcdc_den, lcdc_vsyncn, lcdc_hsyncn, b_data[7:4]}                                                                                                                                                                                                                        |
|                             | lvds_lane4      7'b0                                                                                                                                                                                                                                                                     |
| 3                           | lvds_lane1      {g_data[0],r_data[5:0]}                                                                                                                                                                                                                                                  |
|                             | lvds_lane2      {b_data[1:0],g_data[5:1]}                                                                                                                                                                                                                                                |
|                             | lvds_lane3      {lcdc_den, lcdc_vsyncn, lcdc_hsyncn, b_data[5:2]}                                                                                                                                                                                                                        |
|                             | lvds_lane4      7'b0                                                                                                                                                                                                                                                                     |



Fig. 13-3 LVDS mode clock timing

, When setting grf\_con\_lvds\_msbsel to 0, the output serial data is transmitted as shown in figure bellow. The rising edge of the output clock is at the transition of bit2 and bit1 of the video\_data(r\_data,g\_data,b\_data).



Fig. 13-4 LVDS mode lsb parallel data to serial data timing

### 13.3.5 TTL MODE

The TTL mapping of digital signals to analog pads is shown below.

Table 13-3 TTL mapping of digital signals to analog pads

| Digital Signal | Analog PADS |
|----------------|-------------|
| lc当地 d8m1      | DATAP0      |
| lc当地 d11m1     | DATANO      |
| lc当地 d10m1     | DATAP1      |
| lc当地 d1m1      | DATAN1      |
| lc当地 d5m1      | DATAP2      |
| lc当地 vsyncm1   | DATAN2      |
| lc当地 denm1     | DATAP3      |
| lc当地 hsyncm1   | DATAP3      |
| lc当地 d3m1      | CLKP        |
| lc当地 d4m1      | CLKN        |

## 13.4 Register Description

DSI PHY registers are accessed by APB BUS. This section describes the control/status registers of the design.

### 13.4.1 Register Summary

| Name                         | Offset | Size | Reset Value | Description         |
|------------------------------|--------|------|-------------|---------------------|
| MIPI DSIPHY CTRL LANE ENABLE | 0x0000 | W    | 0x00000001  | lane enable         |
| MIPI DSIPHY CTRL PWR CTL     | 0x0004 | W    | 0x00000003  | power control       |
| MIPI DSIPHY CTRL PREDIV      | 0x000c | W    | 0x00000003  | PLL PREDIV          |
| MIPI DSIPHY CTRL FB DIV      | 0x0010 | W    | 0x0000007d  | PLL FB DIV          |
| MIPI DSIPHY CTRL DIG RST     | 0x0080 | W    | 0x000000ff  | digital logic reset |

| Name                     | Offset | Size | Reset Value | Description   |
|--------------------------|--------|------|-------------|---------------|
| MIPI DSIPHY CTRL SIG INV | 0x0084 | W    | 0x00000002  | signal revert |

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

| Name                           | Offset | Size | Reset Value | Description          |
|--------------------------------|--------|------|-------------|----------------------|
| MIPI DSIPHY LVDSTTL ctrl       | 0x0380 | W    | 0x00000001  | control bit          |
| MIPI DSIPHY LVDSTTL digital_en | 0x0384 | W    | 0x00000012  | digital logic enable |
| MIPI DSIPHY LVDSTTL mode_en    | 0x038c | W    | 0x00000001  | model selection      |
| MIPI DSIPHY LVDSTTL lane_en    | 0x03ac | W    | 0x00000004  | lane enable          |

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

Following table shows registers for 5 lanes. They have same registers but use different address bases. So their final address is lane\_base\_address + offset.

| lane       | lane_base_address |
|------------|-------------------|
| clock_lane | 0x100             |
| Data0_lane | 0x180             |
| Data1_lane | 0x200             |
| Data2_lane | 0x280             |
| Data3_lane | 0x300             |

| Name                                  | Offset | Size | Reset Value | Description        |
|---------------------------------------|--------|------|-------------|--------------------|
| MIPI_DSIPHY_LANEX_Tlp_x               | 0x0014 | W    | 0x000000c5  | Tlpx               |
| MIPI_DSIPHY_LANEX_S_HSTXTHSPRPR       | 0x0018 | W    | 0x00000024  | HSTXTHSPRPR        |
| MIPI_DSIPHY_LANEX_S_HSTXTHSZERO       | 0x001c | W    | 0x00000000  | HSTXTHSZERO        |
| MIPI_DSIPHY_LANEX_S_HSTX              | 0x0020 | W    | 0x00000027  | HSTX               |
| MIPI_DSIPHY_LANEX_Ths_exit            | 0x0024 | W    | 0x0000000a  | Ths_exit           |
| MIPI_DSIPHY_LANEX_Tclk_post           | 0x0028 | W    | 0x0000000f  | Tclk_post          |
| MIPI_DSIPHY_LANEX_LPD_T_TX_PPI_SYN_EN | 0x0030 | W    | 0x00000000  | LPDT_TX_PPI_SYN_EN |
| MIPI_DSIPHY_LANEX_Twakeup             | 0x0034 | W    | 0x00000000  | Twakeup            |
| MIPI_DSIPHY_LANEX_Tclk_pre            | 0x0038 | W    | 0x00000006  | Tclk_pre           |
| MIPI_DSIPHY_LANEX_Tta_go              | 0x0040 | W    | 0x00000004  | Tta_go             |
| MIPI_DSIPHY_LANEX_Tta_sure            | 0x0044 | W    | 0x00000001  | Tta_sure           |
| MIPI_DSIPHY_LANEX_Tta_wait            | 0x0048 | W    | 0x00000032  | Tta_wait           |

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

### 13.4.2 MIPI DSIPHY CTRL Detail Register Description

#### MIPI DSIPHY CTRL LANE ENABLE

Address: Operational Base + offset (0x0000)

| Bit  | Attr | Reset Value | Description                   |
|------|------|-------------|-------------------------------|
| 31:7 | RO   | 0x0         | reserved                      |
| 6    | RW   | 0x0         | lane_en_ck<br>lane clk enable |
| 5    | RW   | 0x0         | lane_en_3<br>lane 3 enable    |
| 4    | RW   | 0x0         | lane_en_2<br>lane 2 enable    |
| 3    | RW   | 0x0         | lane_en_1<br>lane 1 enable    |
| 2    | RW   | 0x0         | lane_en_0<br>lane 0 enable    |
| 1:0  | RO   | 0x0         | reserved                      |

**MIPI DSIPHY CTRL PWRCTL**

Address: Operational Base + offset (0x0004)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>       |
|------------|-------------|--------------------|--------------------------|
| 31:3       | RO          | 0x0                | reserved                 |
| 2          | RW          | 0x0                | SYNCRST<br>analog reset  |
| 1          | RW          | 0x1                | LDO_PD<br>ldo powerdown  |
| 0          | RW          | 0x1                | PLL_PD<br>pll power down |

**MIPI DSIPHY CTRL PREDIV**

Address: Operational Base + offset (0x000c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b> |
|------------|-------------|--------------------|--------------------|
| 31:6       | RO          | 0x0                | reserved           |
| 5          | RW          | 0x0                | FBDIV_HI<br>PREDIV |
| 4:0        | RW          | 0x03               | PREDIV<br>PREDIV   |

**MIPI DSIPHY CTRL FBDIV**

Address: Operational Base + offset (0x0010)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>   |
|------------|-------------|--------------------|----------------------|
| 31:8       | RO          | 0x0                | reserved             |
| 7:0        | RW          | 0x7d               | FBDIV_LO<br>FBDIV_LO |

**MIPI DSIPHY CTRL DIG\_RST**

Address: Operational Base + offset (0x0080)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>             |
|------------|-------------|--------------------|--------------------------------|
| 31:1       | RO          | 0x0                | reserved                       |
| 0          | RW          | 0x1                | dig_rst<br>digital logic reset |

**MIPI DSIPHY CTRL SIG INV**

Address: Operational Base + offset (0x0084)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                         |
|------------|-------------|--------------------|------------------------------------------------------------|
| 31:2       | RO          | 0x0                | reserved                                                   |
| 1          | RW          | 0x0                | PIN_TXCLKESC_0_INV_EN<br>inverting pin_txclkesc_0 enable   |
| 0          | RW          | 0x0                | PIN_TXBUTECLKHS_INV_EN<br>inverting pin_txbyteclkhs enable |

**13.4.3 MIPI DSIPHY LANEx Detail Register Description****MIPI DSIPHY LANEX Tlpx**

Address: Operational Base + offset (0x0014)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------|
| 31:6       | RO          | 0x0                | reserved                                                                                    |
| 5:0        | RW          | 0x00               | Tlpx<br>The value of counter for HS Tlpx<br>Time (>=Tlpx)<br>= Tpin_txbyteclkhs * (2+value) |

**MIPI DSIPHY LANEX S HSTXTHSPRPR**

Address: Operational Base + offset (0x0018)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:7       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 6:0        | RW          | 0x24               | S_HSTXTHSPRPR<br>The value of counter for HS Ths-prepare<br>For clock lane, Ths-prepare(38ns~95ns)<br>For data lane, Ths-prepare(40ns+4UI~85ns+6UI)<br>For clock lane, S_HSTXTHSPRPR[6:0] = 7'b0100100<br>For data lane, S_HSTXTHSPRPR[6:0] = 7'b0100100<br>Frequency(1/UI) Value(HEX)<br>80-110MHz 20<br>110-150 MHz 06<br>150-200 MHz 18<br>200-250 MHz 05<br>250-300 MHz 51<br>300-400 MHz 64<br>400-500 MHz 59<br>500-600 MHz 6A<br>600-700 MHz 3E<br>700-800 MHz 21<br>800-1000 MHz 09 |

**MIPI DSIPHY LANEX S HSTXTHSZERO**

Address: Operational Base + offset (0x001c)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5:0        | RW          | 0x00               | <p>S_HSTXTHSZERO<br/> For clock lane, Ths-prepare+Ths-zero (&gt;=300ns)<br/> For data lane, Ths-prepare+Ths-zero (&gt;= 145 ns + 10*UI)<br/> = Tpin_txbyteclkhs*(5+value)<br/> For clock lane, S_HSTXTHSZERO[5:0] = 6'b100000<br/> Frequency(1/UI) Value(HEX)</p> <p>80 -110 MHz 16<br/> 110-150 MHz 16<br/> 150-200 MHz 17<br/> 200-250 MHz 17<br/> 250-300 MHz 18<br/> 300-400 MHz 19<br/> 400-500 MHz 1B<br/> 500-600 MHz 1D<br/> 600-700 MHz 1E<br/> 700-800 MHz 1F<br/> 800-1000 MHz 20<br/> For data lane,S_HSTXTHSZERO[5:0] = 6'b001001<br/> Frequency(1/UI) Value(HEX)</p> <p>80 -110 MHz 2<br/> 110-150 MHz 3<br/> 150-200 MHz 4<br/> 200-250 MHz 5<br/> 250-300 MHz 6<br/> 300-400 MHz 7<br/> 400-500 MHz 7<br/> 500-600 MHz 8<br/> 600-700 MHz 8<br/> 700-800 MHz 9<br/> 800-1000 MHz 9</p> |

**MIPI DSIPHY LANEX S HSTX**

Address: Operational Base + offset (0x0020)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6:0        | RW          | 0x27               | <p>S_HSTX<br/>The value of counter for HS Ths-trail<br/>For clock lane, Ths-trail (<math>&gt;=60\text{ns}</math>)<br/>For data lane, Ths-trail (<math>&gt;=\max(8\text{UI}, 60\text{ns}+4\text{UI})</math>)<br/>For clock lane, S_HXTXTHSTRAIL[6:0] = 7'b0100111<br/>For data lane, S_HXTXTHSTRAIL[6:0] = 7'b0100111<br/>Frequency(1/UI) Value(HEX)<br/>80 -110 MHz 22<br/>110-150 MHz 45<br/>150-200 MHz 0B<br/>200-250 MHz 16<br/>250-300 MHz 2C<br/>300-400 MHz 33<br/>400-500 MHz 4E<br/>500-600 MHz 3A<br/>600-700 MHz 6A<br/>700-800 MHz 29<br/>800-1000 MHz 27</p> |

**MIPI DSIPHY LANEX Ths\_exit**

Address: Operational Base + offset (0x0024)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x0                | reserved                                                                                           |
| 4:0        | RW          | 0x0a               | <p>Ths_exit<br/>The value of counter for HS Ths-exit<br/>Ths-exit<br/>= Tpin_txbyteclkhs*value</p> |

**MIPI DSIPHY LANEX Tclk\_post**

Address: Operational Base + offset (0x0028)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------|
| 31:4       | RO          | 0x0                | reserved                                                                                            |
| 3:0        | RW          | 0xf                | <p>Tclk_post<br/>The value of counter for HS Ths-exit<br/>Ths-exit<br/>= Tpin_txbyteclkhs*value</p> |

**MIPI DSIPHY LANEX LPDT TX PPI SYN EN**

Address: Operational Base + offset (0x0030)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                    |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------|
| 2          | RW          | 0x0                | LPDT_TX_PPI_SYN_EN<br>LPDT TX PPI signals internal synchronization enable.<br>1: enable<br>0: disable |
| 1:0        | RW          | 0x0                | Twakup_H<br>The value[9:8] of counter for HS Twakup                                                   |

**MIPI DSIPHY LANEX Twakup**

Address: Operational Base + offset (0x0034)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                                                                                     |
| 7:0        | RW          | 0x00               | Twakup<br>The value[7:0] of counter for HS Twakup<br>Twakup for ulpm,<br>Twakup<br>= Tpin_sys_clk*value[9:0] |

**MIPI DSIPHY LANEX Tclk\_pre**

Address: Operational Base + offset (0x0038)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>   |
|------------|-------------|--------------------|----------------------|
| 31:4       | RO          | 0x0                | reserved             |
| 3:0        | RW          | 0x6                | Tclk_pre<br>Tclk_pre |

**MIPI DSIPHY LANEX Tta\_go**

Address: Operational Base + offset (0x0040)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------|
| 31:6       | RO          | 0x0                | reserved                                                                                             |
| 5:0        | RW          | 0x04               | Tta_go<br>The value of counter for HS Tta-go<br>Tta-go for turnaround<br>Tta-go<br>= Ttxclkesc*value |

**MIPI DSIPHY LANEX Tta\_sure**

Address: Operational Base + offset (0x0044)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------|
| 31:6       | RO          | 0x0                | reserved                                                                    |
| 5:0        | RW          | 0x01               | Tta_sure<br>The value of counter for HS Tta-sure<br>Tta-sure for turnaround |

**MIPI DSIPHY LANEX Tta\_wait**

Address: Operational Base + offset (0x0048)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6       | RO          | 0x0                | reserved                                                                                                                                                                               |
| 5:0        | RW          | 0x00               | Tta_wait<br>The value of counter for HS Tta-wait<br>Tta-wait for turnaround<br>Interval from receiving ppi turnaround request to sending esc request.<br>Tta-wait<br>= Ttxclkesc*value |

### 13.4.4 MIPI DSIPHY LVDS/TTL Detail Register Description

#### MIPI DSIPHY LVDSTTL ctrl

Address: Operational Base + offset (0x0380)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                         |
|------------|-------------|--------------------|------------------------------------------------------------|
| 31:3       | RO          | 0x0                | reserved                                                   |
| 2          | RW          | 0x0                | digital_internal_reset<br>digital logic reset              |
| 1          | RO          | 0x0                | reserved                                                   |
| 0          | RW          | 0x1                | bit_order<br>selection for MSB and LSB<br>1: MSB<br>0: LSB |

#### MIPI DSIPHY LVDSTTL digital en

Address: Operational Base + offset (0x0384)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                                                   |
| 7          | RW          | 0x0                | digital_internal_en<br>digital internal enable<br>Active high. Default low |
| 6:0        | RO          | 0x0                | reserved                                                                   |

#### MIPI DSIPHY LVDSTTL mode en

Address: Operational Base + offset (0x038c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------|
| 31:3       | RO          | 0x0                | reserved                                                                        |
| 2          | RW          | 0x0                | ttl_mode_en<br>TTL mode enable<br>1: enable TTL mode<br>0: disable TTL mode     |
| 1          | RW          | 0x0                | lvds_mode_en<br>LVDS mode enable<br>1: enable LVDS mode<br>0: disable LVDS mode |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------|
| 0          | RW          | 0x1                | mipi_mode_en<br>mipi mode enable<br>1: enable mipi mode<br>0: disable mipi mode |

**MIPI DSIPHY LVDSTTL lane\_en**

Address: Operational Base + offset (0x03ac)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                                                                          |
| 7          | RW          | 0x0                | data_lane0_en<br>Data Lane0 enable for LVDS mode<br>1: enable Data Lane0<br>0: disable Data Lane0 |
| 6          | RW          | 0x0                | data_lane1_en<br>Data Lane1 enable for LVDS mode<br>1: enable Data Lane1<br>0: disable Data Lane1 |
| 5          | RW          | 0x0                | data_lane2_en<br>Data Lane2 enable for LVDS mode<br>1: enable Data Lane2<br>0: disable Data Lane2 |
| 4          | RW          | 0x0                | data_lane3_en<br>Data Lane3 enable for LVDS mode<br>1: enable Data Lane3<br>0: disable Data Lane3 |
| 3          | RW          | 0x0                | clk_lane_en<br>Clock Lane enable for LVDS mode<br>1: enable Clock Lane<br>0: disable Clock Lane   |
| 2          | RW          | 0x1                | pll_pwr_off<br>PLL power off enable for LVDS mode<br>1: power off<br>0: power on                  |
| 1:0        | RO          | 0x0                | reserved                                                                                          |

## 13.5 Application Notes

### 13.5.1 COMMON CONFIGURATION (DEFAULT IN MIPI MODE)

Step1: Enable reference clock.

Step2: Wait a period after reference clock have been enabled.

Step3: Send 0xe4 to register MIPI\_DSI\_DPHY\_CTRL\_PWRCTL. Enable PLL and LDO.

Step4: Send 0x7d to register MIPI\_DSI\_DPHY\_CTRL\_LANE\_ENABLE. Enable all lanes on analog part.

Step5: Send 0xe0 to register MIPI\_DSI\_DPHY\_CTRL\_PWRCTL. Reset analog.

Step6: Wait a period after analog has been reset.

Step7: Send 0x1e to register MIPI\_DSI\_DPHY\_CTRL\_DIG\_RST. Reset digital.

Step8: Send 0x1f to register MIPI\_DSI\_DPHY\_CTRL\_DIG\_RST. Reset digital.

Step9: Wait a period until pll locked. Run in MIPI mode.

### **13.5.2 CONFIGURATION FOR LVDS MODE**

Step1: Firstly perform common configuration.

Step2: Configure PLL.

Write 8'h01 to the register MIPI\_DSI\_DPHY\_CTRL\_PREDIV;

Write 8'h0e to the register MIPI\_DSI\_DPHY\_CTRL\_FBDIV;

Step3: (optional) Select lsb mode, default msb mode.

Write 8'h44 to the register DPHY\_LVDS\_TTL\_SETTIING\_ctrl;

Step4: Enable LVDS digital logic.

Write 8'h92 to the register DPHY\_LVDS\_TTL\_SETTIING\_digital\_en;

Step5: Enable LVDS analog driver.

Write 8'h f8 to the register DPHY\_LVDS\_TTL\_SETTIING\_lane\_en;

Step6: Select LVDS mode.

Write 8'h 02 to the register DPHY\_LVDS\_TTL\_SETTIING\_mode\_en;

Step7: Wait a period until PLL locked. Run in LVDS mode.

### **13.5.3 CONFIGURATION FOR TTL MODE**

Step1: Select TTL mode.

Write 8'h04 to the register DPHY\_LVDS\_TTL\_SETTIING\_mode\_en;

Step2: Enable analog driver.

Write 8'hfd to the register DPHY\_LVDS\_TTL\_SETTIING\_lane\_en;

Step3: Run in TTL mode.

### **13.5.4 LOW POWER MODE (FOR DSI ONLY)**

Low Power Mode is a special feature for D-PHY. You can control this function by using proper registers from the D-PHY with few operations. The following is a step by step instruction for low power mode in and out.

- Low Power in Steps:

Step1: Send 0x01 to register MIPI\_DSI\_DPHY\_CTRL\_LANE\_ENABLE. Disable all lanes on analog part.

Step2: Send 0xe3 to register MIPI\_DSI\_DPHY\_CTRL\_PWRCTL. Disable PLL and LDO.

Step3: Wait a period before reference clock have been disabled.

Step4: Disable reference clock.

- Low Power out Steps:

Step1: Enable reference clock.

Step2: Wait a period after reference clock have been enabled.

Step3: Send 0xe4 to register MIPI\_DSI\_DPHY\_CTRL\_PWRCTL. Enable PLL and LDO.

Step4: Send 0x7d to register MIPI\_DSI\_DPHY\_CTRL\_LANE\_ENABLE. Enable all lanes on analog part.

Step5: Send 0xe0 to register MIPI\_DSI\_DPHY\_CTRL\_PWRCTL. Reset analog.

Step6: Wait a period after analog has been reset.

Step7: Send 0x1e to register MIPI\_DSI\_DPHY\_CTRL\_DIG\_RST. Reset digital.

Step8: Send 0x1f to register MIPI\_DSI\_DPHY\_CTRL\_DIG\_RST. Reset digital.

Step9: Wait a period before normal transmission.

## Chapter 14 MIPI CSI D-PHY

### 14.1 Overview

The MIPI CSI D-PHY is compliant with the MIPI D-PHY interface specification, revision 1.0. The MIPI CSI D-PHY is used for slave applications. The MIPI CSI D-PHY is targeted for receive the camera video digital data in mobile applications, supporting a maximum effective bit rate of 1.0Gbps per lane. The assembled four-data-lane system enables up to 4Gbps aggregate communication throughputs, delivering the bandwidth needed for high-throughput data transfer.

The MIPI D-PHY supports the following features:

- Mixed-signal D-PHY mixed-signal hard-macro- HS/LS Transmitter and LS/HS Receiver solution
- Designed to MIPI® v1.0 Specifications
- Integrated PHY Protocol Interface (PPI) supports interface to CSI and UniPro™ MIPI® protocol
- 1.0GHz maximum data transfer rate per lane
- Expandable to support 4 data lanes, providing up to 4Gbps transfer rate
- 10Mbps per lane in low-power mode
- Unidirectional and bi-directional modes supported
- Automatic termination control for HS and LP modes
- Low-Power dissipation: less than 3mA/Lane in HS RX mode
- Rx Buffers with tunable On-Die-Termination and advanced equalization.
- Embedded ESD, boundary scan support logic.

### 14.2 Block Diagram



Fig. 14-1 MIPI CSI D-PHY detailed block diagram

MIPI CSI D-PHY configuration contains one Clock Lane Module and four Data Lane Modules. Each of these PHY Lane Modules communicates via two Lines to a complementary part at the other side of the Lane Interconnect.

### 14.3 Function Description

#### 14.3.1 System Connection

MIPI CSI D-PHY registers are configured by software, but its input ports phy\_forcerxmode, phy\_datalane\_en, phy\_clklane\_en are configured by grf register. D-PHY output video data feeds ISP. The connection shows in following figure:



Fig. 14-2 MIPI CSI D-PHY and ISP connection

In MIPI mode, there are some functions of DPHY controlled by grf registers. These register bit and function is show in following table:

Table 14-1 function of grf bits in MIPI mode

| register bit                    | function                                                                                                                                                                          |
|---------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| grf_con_csiphy_clkinv_selection | Reverse for receive clock                                                                                                                                                         |
| grf_con_csiphy_clklane_en       | Receiver Clock Active. This asynchronous, active high signal indicates that a Clock Lane is receiving a DDR clock signal.                                                         |
| grf_con_csiphy_datalane_en_3    | Receiver Data Lane Active. This active low signal is asserted to indicate that the Lane is in ULP state.                                                                          |
| grf_con_csiphy_datalane_en_2    | Receiver Data Lane Active. This active low signal is asserted to indicate that the Lane is in ULP state.                                                                          |
| grf_con_csiphy_datalane_en_1    | Receiver Data Lane Active. This active low signal is asserted to indicate that the Lane is in ULP state.                                                                          |
| grf_con_csiphy_datalane_en_0    | Receiver Data Lane Active. This active low signal is asserted to indicate that the Lane is in ULP state.                                                                          |
| grf_con_csiphy_forcerxmode_3    | Force Lane Module Into Receive mode / Wait for Stop state. This signal allows the protocol to initialize a Lane Module, or force a bi-directional Lane Module, into receive mode. |
| grf_con_csiphy_forcerxmode_2    | Force Lane Module Into Receive mode / Wait for Stop state. This signal allows the protocol to initialize a Lane Module, or force a bi-directional Lane Module, into receive mode. |
| grf_con_csiphy_forcerxmode_1    | Force Lane Module Into Receive mode / Wait for Stop state. This signal allows the protocol to initialize a Lane Module, or force a bi-directional Lane Module, into receive mode. |

| register bit                 | function                                                                                                                                                                          |
|------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| grf_con_csiphy_forcerxmode_0 | Force Lane Module Into Receive mode / Wait for Stop state. This signal allows the protocol to initialize a Lane Module, or force a bi-directional Lane Module, into receive mode. |

## 14.4 Register Description

This section describes the control/status registers of the design.

### 14.4.1 Register Summary

| Name                               | Offset | Size | Reset Value | Description   |
|------------------------------------|--------|------|-------------|---------------|
| MIPI CSI DPHY CTRL LA<br>NE_ENABLE | 0x0000 | W    | 0x00000001  | lane enable   |
| MIPI CSI DPHY CTRL P<br>WRCTL      | 0x0004 | W    | 0x00000003  | power control |
| MIPI CSI DPHY CTRL DI<br>G_RST     | 0x0080 | W    | 0x000000ff  | digital reset |
| MIPI CSI DPHY CTRL SI<br>G_INV     | 0x0084 | W    | 0x00000000  | signal invert |

Notes: **Size:** **B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access  
Following table shows registers for 5 lanes. They have same registers but use different address bases. So their final address is lane\_base\_address + offset.

Table 14-2 registers address for 5 lanes table

| lane       | lane_base_address |
|------------|-------------------|
| clock_lane | 0x100             |
| Data0_lane | 0x180             |
| Data1_lane | 0x200             |
| Data2_lane | 0x280             |
| Data3_lane | 0x300             |

Following table shows the registers for LANE configuration.

Table 14-3 registers configuration for 5 lanes table

| Name                               | Offset | Size | Reset Value | Description |
|------------------------------------|--------|------|-------------|-------------|
| MIPI CSI DPHY LANEX T<br>HS_SETTLE | 0x0000 | W    | 0x0000000b  | THS_SETTLE  |
| MIPI CSI DPHY LANEX<br>MSB_EN      | 0x0038 | W    | 0x00000000  | MSB_EN      |

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

### 14.4.2 Detail Register Description

#### MIPI CSI DPHY CTRL LANE ENABLE

Address: Operational Base + offset (0x0000)

| Bit  | Attr | Reset Value | Description                     |
|------|------|-------------|---------------------------------|
| 31:7 | RO   | 0x0         | reserved                        |
| 6    | RW   | 0x0         | lane_en_ck<br>lane clock enable |
| 5    | RW   | 0x0         | lane_en_3<br>lane 3 enable      |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>         |
|------------|-------------|--------------------|----------------------------|
| 4          | RW          | 0x0                | lane_en_2<br>lane 1 enable |
| 3          | RW          | 0x0                | lane_en_1<br>lane 1 enable |
| 2          | RW          | 0x0                | lane_en_0<br>lane 0 enable |
| 1:0        | RO          | 0x0                | reserved                   |

**MIPI CSI DPHY CTRL PWRCTL**

Address: Operational Base + offset (0x0004)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>       |
|------------|-------------|--------------------|--------------------------|
| 31:3       | RO          | 0x0                | reserved                 |
| 2          | RW          | 0x0                | SYNCRST<br>reset phy     |
| 1          | RW          | 0x1                | LDO_PD<br>ldo power down |
| 0          | RW          | 0x1                | PLL_PD<br>pll powerdown  |

**MIPI CSI DPHY CTRL DIG\_RST**

Address: Operational Base + offset (0x0080)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>             |
|------------|-------------|--------------------|--------------------------------|
| 31:1       | RO          | 0x0                | reserved                       |
| 0          | RW          | 0x0                | dig_rst<br>digital logic reset |

**MIPI CSI DPHY CTRL SIG\_INV**

Address: Operational Base + offset (0x0084)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                         |
|------------|-------------|--------------------|------------------------------------------------------------|
| 31:4       | RO          | 0x0                | reserved                                                   |
| 3          | RW          | 0x0                | PIN_RXBYTECLKHS_INV_EN<br>inverting pin_rxbyteclkhs enable |
| 2:0        | RO          | 0x0                | reserved                                                   |

**MIPI CSI DPHY LANEX THS SETTLE**

Address: Operational Base + offset (0x0000)

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

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-----|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0 | RW   | 0xb         | <p>Tlpx</p> <p>Configure the count time of the THS-SETTLE by protocol.</p> <p>After the count done, D-PHY will begin to receive the high speed data.</p> <p>(Can be configured from 4'h0 to 4'hd)</p> <p>4'b0000 80-110 MHz<br/>         4'b0001 110-150 MHz<br/>         4'b0010 150-200 MHz<br/>         4'b0011 200-250 MHz<br/>         4'b0100 250-300 MHz<br/>         4'b0101 300-400 MHz<br/>         4'b0110 400-500 MHz<br/>         4'b0111 500-600 MHz<br/>         4'b1000 600-700 MHz<br/>         4'b1001 700-800 MHz<br/>         4'b1010 800-1000 MHz<br/>         4'b1011 additional adjust<br/>         4'b1100 additional adjust<br/>         4'b1101 additional adjust<br/>         4'b1110 additional adjust</p> |

**MIPI CSI DPHY LANEX MSB EN**

Address: Operational Base + offset (0x0038)

| Bit  | Attr | Reset Value | Description                                                                                 |
|------|------|-------------|---------------------------------------------------------------------------------------------|
| 31:7 | RO   | 0x0         | reserved                                                                                    |
| 6    | RW   | 0x0         | <p>MSB_EN</p> <p>MSB enable for pin_rxdatahs_*</p> <p>1: enable<br/>         0: disable</p> |
| 5:0  | RO   | 0x0         | reserved                                                                                    |

## 14.5 Application Notes

### 14.5.1 LOW POWER MODE

Low Power Mode is a special feature for D-PHY. You can control this function by using proper registers from the D-PHY with few operations. The following is a step by step instruction for low power mode in and out.

- Low Power in Steps:

Step1: Send 0x01 to register MIPI\_CSI\_DPHY\_CTRL\_LANE\_ENABLE. Disable all lanes on analog part.

Step2: Send 0xe3 to register MIPI\_CSI\_DPHY\_CTRL\_PWRCTL. Disable PLL and LDO.

Step3: Wait a period before reference clock have been disabled.

Step4: Disable reference clock.

- Low Power out Steps:

Step1: Enable reference clock.

Step2: Wait a period after reference clock have been enabled.

Step3: Send 0xe4 to register MIPI\_CSI\_DPHY\_CTRL\_PWRCTL. Enable PLL and LDO.

Step4: Send 0x7d to register MIPI\_CSI\_DPHY\_CTRL\_LANE\_ENABLE. Enable all lanes on

analog part.

Step5: Send 0xe0 to register MIPI\_CSI\_DPHY\_CTRL\_PWRCTL. Reset analog.

Step6: Wait a period after analog has been reset.

Step7: Send 0x1e to register MIPI\_CSI\_DPHY\_CTRL\_DIG\_RST. Reset digital.

Step8: Send 0x1f to register MIPI\_CSI\_DPHY\_CTRL\_DIG\_RST. Reset digital.

Step9: Wait a period before normal transmission.

### **14.5.2 COMMON CONFIGURATION (DEFAULT IN MIPI MODE)**

Step1: Enable reference clock.

Step2: Wait a period after reference clock have been enabled.

Step3: Send 0xe4 to register MIPI\_CSI\_DPHY\_CTRL\_PWRCTL. Enable PLL and LDO.

Step4: Send 0x7d to register MIPI\_CSI\_DPHY\_CTRL\_LANE\_ENABLE. Enable all lanes on analog part.

Step5: Send 0xe0 to register MIPI\_CSI\_DPHY\_CTRL\_PWRCTL. Reset analog.

Step6: Wait a period after analog has been reset.

Step7: Send 0x1e to register MIPI\_CSI\_DPHY\_CTRL\_DIG\_RST. Reset digital.

Step8: Send 0x1f to register MIPI\_CSI\_DPHY\_CTRL\_DIG\_RST. Reset digital.

Step9: Wait a period until pll locked. Run in MIPI mode.