

***Rockchip  
RK3036  
Technical Reference Manual  
System and System Control***

**Revision 1.0  
Sep. 2015**

## **Revision History**

| <b>Date</b> | <b>Revision</b> | <b>Description</b>                     |
|-------------|-----------------|----------------------------------------|
| 2015-9-7    | 1.0             | Update-Part1 System and System Control |

## Table of Content

|                                                 |     |
|-------------------------------------------------|-----|
| Table of Content .....                          | 3   |
| Figure Index .....                              | 5   |
| Table Index.....                                | 6   |
| Warranty Disclaimer.....                        | 7   |
| Chapter 1 Introduction .....                    | 8   |
| 1.1 Features .....                              | 8   |
| 1.2 Block Diagram .....                         | 15  |
| Chapter 2 System Overview .....                 | 16  |
| 2.1 Address Mapping.....                        | 16  |
| 2.2 System Boot.....                            | 16  |
| 2.3 System Interrupt connection.....            | 18  |
| 2.4 System DMA hardware request connection..... | 21  |
| Chapter 3 Clock & Reset Unit (CRU) .....        | 22  |
| 3.1 Overview .....                              | 22  |
| 3.2 Block Diagram .....                         | 22  |
| 3.3 System Reset Solution .....                 | 22  |
| 3.4 Function Description .....                  | 23  |
| 3.5 PLL Introduction.....                       | 23  |
| 3.6 Register Description .....                  | 24  |
| 3.7 Timing Diagram .....                        | 64  |
| 3.8 Application Notes .....                     | 64  |
| Chapter 4 Embedded Processor (Cortex-A7).....   | 67  |
| 4.1 Overview .....                              | 67  |
| 4.2 Block Diagram .....                         | 67  |
| 4.3 Function Description .....                  | 67  |
| 4.4 Register Description .....                  | 67  |
| Chapter 5 General Register Files (GRF).....     | 68  |
| 5.1 Overview .....                              | 68  |
| 5.2 Function Description .....                  | 68  |
| 5.3 Register Description .....                  | 68  |
| Chapter 6 DMC (Dynamic Memory Interface).....   | 124 |
| 6.1 Overview .....                              | 124 |
| 6.2 Block Diagram .....                         | 125 |
| 6.3 Function Description .....                  | 125 |
| 6.4 Register Description .....                  | 127 |
| 6.5 Timing Diagram .....                        | 170 |
| 6.6 Interface Description .....                 | 171 |
| 6.7 Application Notes .....                     | 171 |
| Chapter 7 Nand Flash Controller (NandC).....    | 179 |
| 7.1 Overview .....                              | 179 |
| 7.2 Block Diagram .....                         | 180 |
| 7.3 Function Description .....                  | 180 |
| 7.4 Register Description .....                  | 181 |
| 7.5 Interface Description .....                 | 207 |
| 7.6 Application Notes .....                     | 208 |
| Chapter 8 Timer .....                           | 215 |
| 8.1 Overview .....                              | 215 |
| 8.2 Block Diagram .....                         | 215 |
| 8.3 Function Description .....                  | 215 |

|                                                             |     |
|-------------------------------------------------------------|-----|
| 8.4 Register Description .....                              | 216 |
| 8.5 Application Notes .....                                 | 218 |
| Chapter 9 Generic Interrupt Controller (GIC).....           | 219 |
| 9.1 Overview .....                                          | 219 |
| 9.2 Block Diagram .....                                     | 219 |
| Chapter 10 DMA Controller(DMAC).....                        | 220 |
| 10.1 Overview.....                                          | 220 |
| 10.2 Block Diagram .....                                    | 220 |
| 10.3 Function Description .....                             | 221 |
| 10.4 Register Description.....                              | 222 |
| 10.5 Timing Diagram .....                                   | 238 |
| 10.6 Interface Description.....                             | 238 |
| 10.7 Application Notes.....                                 | 239 |
| Chapter 11 Process-Voltage-Temperature Monitor (PVTM) ..... | 245 |
| 11.1 Overview.....                                          | 245 |
| 11.2 Block Diagram .....                                    | 245 |
| 11.3 Function Description .....                             | 245 |
| 11.4 Application Notes.....                                 | 246 |
| Chapter 12 EFUSE.....                                       | 247 |
| 12.1 Overview.....                                          | 247 |
| 12.2 Block Diagram .....                                    | 247 |
| 12.3 Function Description .....                             | 247 |
| 12.4 Register Description.....                              | 248 |
| 12.5 Timing Diagram .....                                   | 249 |
| 12.6 Application Notes.....                                 | 250 |
| Chapter 13 WatchDog .....                                   | 251 |
| 13.1 Overview.....                                          | 251 |
| 13.2 Block Diagram .....                                    | 251 |
| 13.3 Function Description .....                             | 251 |
| 13.4 Operation .....                                        | 251 |
| 13.5 Programming sequence                                   | 252 |
| 13.6 Register Description.....                              | 252 |
| 13.7 Application Notes.....                                 | 255 |
| Chapter 14 System Debug .....                               | 256 |
| 14.1 Overview.....                                          | 256 |
| 14.2 Block Diagram .....                                    | 256 |
| 14.3 Function Description .....                             | 256 |
| 14.4 Register Description.....                              | 256 |
| 14.5 Interface Description.....                             | 257 |

## Figure Index

|                                                     |     |
|-----------------------------------------------------|-----|
| Fig. 1-1 RK3036 Block Diagram .....                 | 15  |
| Fig. 2-1 RK3036 Address Mapping.....                | 16  |
| Fig. 2-2 RK3036 boot procedure flow.....            | 18  |
| Fig. 3-1 CRU Architecture .....                     | 22  |
| Fig. 3-2 Reset Architecture Diagram .....           | 22  |
| Fig. 3-3 PLL Block Diagram .....                    | 24  |
| Fig. 3-4 Chip Power On Reset Timing Diagram .....   | 64  |
| Fig. 4-1 MP Subsystem architecture .....            | 67  |
| Fig. 7-1 NandC Block Diagram .....                  | 180 |
| Fig. 7-2 NandC Address Assignment.....              | 210 |
| Fig. 7-3 NandC Data Format.....                     | 211 |
| Fig. 7-4 NandC LLP Data Format .....                | 213 |
| Fig. 8-1 Timer Block Diagram .....                  | 215 |
| Fig. 8-2 Timer Usage Flow .....                     | 216 |
| Fig. 8-3 Timing between timer_en and timer_clk..... | 218 |
| Fig. 9-1 GIC Block Diagram.....                     | 219 |
| Fig. 10-1 Block diagram of DMAC.....                | 220 |
| Fig. 10-2 DMAC operation states.....                | 221 |
| Fig. 10-3 DMAC request and acknowledge timing ..... | 238 |
| Fig. 11-1 PVTM Block Diagram.....                   | 245 |
| Fig. 12-1 EFUSE Block Diagram .....                 | 247 |
| Fig. 12-2 EFUSE Timing Diagram in PGM Mode.....     | 249 |
| Fig. 12-3 EFUSE Timing Diagram in Read Mode .....   | 250 |
| Fig. 13-1 WDT block diagram .....                   | 251 |
| Fig. 13-2 WDT Operation Flow .....                  | 252 |
| Fig. 14-1 Debug system structure .....              | 256 |
| Fig. 14-2 DAP SWJ interface.....                    | 257 |
| Fig. 14-3 SW-DP acknowledgement timing .....        | 257 |

## Table Index

|                                                                         |     |
|-------------------------------------------------------------------------|-----|
| Table 2-1 RK3036 Interrupt connection list.....                         | 19  |
| Table 2-2 RK3036 DMAC_PERI Hardware request connection list .....       | 21  |
| Table 6-1 meaning of the parameter.....                                 | 170 |
| Table 6-2 DDR IO description .....                                      | 171 |
| Table 6-3 DDR PHY TX DLLs Delay Step .....                              | 175 |
| Table 6-4 DDR PHY RX DQS Delay Step.....                                | 176 |
| Table 6-5 DM/DQ/DQS/CMD Driver output resistance.....                   | 176 |
| Table 6-6 DM, DQ Signal Drive Strength Register .....                   | 176 |
| Table 6-7 DM/DQ/DQS/CMD Driver output resistance with control bit ..... | 176 |
| Table 6-8 DM/DQ/DQS RX ODT resistance with control bit .....            | 176 |
| Table 6-9 Low Power DLL Setting .....                                   | 177 |
| Table 6-10 per-bit de-skew tuning resolution .....                      | 177 |
| Table 7-1 NandC Address Mapping .....                                   | 181 |
| Table 7-2 NandC Interface Description .....                             | 207 |
| Table 7-3 NandC Interface Connection .....                              | 208 |
| Table 7-4 NandC Page/Spare size for flash.....                          | 212 |
| Table 10-1 DMAC Request Mapping Table .....                             | 220 |
| Table 10-2 DMAC boot interface.....                                     | 238 |
| Table 10-3 Source size in CCRn.....                                     | 242 |
| Table 10-4 DMAC Instruction sets .....                                  | 243 |
| Table 10-5 DMAC instruction encoding .....                              | 244 |
| Table 11-1 core_pvtm control source and result destination .....        | 245 |
| Table 11-2 gpu_pvtm control source and result destination.....          | 246 |
| Table 11-3 video_pvtm control source and result destination.....        | 246 |
| Table 12-1 EFUSE Operation Mode .....                                   | 247 |
| Table 12-2 EFUSE Read Mode .....                                        | 248 |
| Table 12-3 EFUSE Timing Requirements in PGM Mode .....                  | 249 |
| Table 12-4 EFUSE Timing Requirements in Read Mode .....                 | 250 |
| Table 14-1 SW-DP Interface Description .....                            | 257 |

## **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 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 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 © 2015 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 Introduction

RK3036 is a low power consumption, high performance processor solution for low-end OTT TV BOX, and other digital multimedia applications, and integrates dual-core Cortex-A7, with separate NEON coprocessor and 128KB L2 Cache.

Many embedded powerful hardware engines provide optimized performance for high-end application. RK3036 supports almost full-format 1080P H.264 decoder and H.265 decoder, high-quality JPEG decoder and special image preprocessor and postprocessor.

Embedded 3D GPU makes RK3036 completely compatible with OpenGL ES1.1 and 2.0, OpenVG1.1 etc.

RK3036 has high-performance external memory interface (DDR3/DDR3L) capable of sustaining demanding memory bandwidths, also provides a complete set of peripheral interface to support very flexible applications.

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

#### 1.1.1 Micro Processor

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

#### 1.1.2 Internal Memory

- Internal BootRom
  - Size : 16KB
  - Support system boot from the following device:
    - ◆ 8bits Asynchronous Nand Flash
    - ◆ SPI Nand Flash
    - ◆ SPI Nor Flash
    - ◆ eMMC card
    - ◆ SD card
  - Support system code download by the following interface:
    - ◆ USB OTG interface
- Internal SRAM
  - Size : 8KB

#### 1.1.3 External Memory or Storage device

- Dynamic Memory Interface (DDR3-1066/DDR3L-1066)
  - Compatible with JEDEC standard DDR3/DDR3L SDRAM
  - Support up to 2 ranks (chip selects), maximum 2GB address space
  - data width is 8bits or 16bits, software programmable
  - Four host ports with 64bits/128bits AXI bus interface for system access, AXI bus clock

- is asynchronous with DDR clock
- Programmable timing parameters to support DDR3/DDR3L SDRAM from various vendor
- Advanced command reordering and scheduling to maximize bus utilization
- Low power modes, such as power-down and self-refresh for DDR3 /DDR3L SDRAM
- Programmable output and ODT impedance with dynamic PVT compensation
- Support one low-power work mode: power down DDR PHY and most of DDR IO except two cs and cke output signals, make SDRAM still in self-refresh state to prevent data missing
- Nand Flash Interface
  - Support asynchronous nand flash, each channel 8bits, 1 bank
  - Support configurable interface timing
  - Embedded special DMA interface to do data transfer
- eMMC Interface
  - Compatible with standard iNAND interface
  - Support MMC4.5 protocol
  - Provide eMMC boot sequence to receive boot data from external eMMC device
  - Embedded clock adjustment for high speed transfer
  - Support 8bits data width with signal data rate or dual data rate
- SD/MMC Interface
  - Compatible with SD3.0, MMC4.5
  - Support FIFO over-run and under-run prevention by stopping card clock automatically
  - Embedded clock adjustment for high speed transfer
  - Support 4bits data width signal data rate or dual data rate
- Serial Flash Controller(SFC)
  - One on-chip SFC
  - Support command/address/data x1/x2/x4 bits mode configurable
  - Support 2 chip select
  - Support connected to serial nor flash or serial nand flash

#### **1.1.4 System Component**

- CRU (clock & reset unit)
  - Support clock gating control for individual components
  - One oscillator with 24MHz clock input and three embedded PLLs: ARM PLL, DDR PLL, GENERAL PLL
  - Support global soft-reset control for whole SOC, also individual soft-reset for every components
- Timer
  - Four on-chip 64bits Timers in SoC with interrupt-based operation
  - Provide two operation modes: free-running and user-defined count
  - Support timer work state checkable
- PWM
  - Four on-chip PWMs with interrupt-based operation
  - Programmable pre-scaled operation to input clock and then further scaled
  - Embedded 32-bit timer/counter facility
  - Support capture mode
  - Support continuous mode or one-shot mode
  - Provides reference mode and output various duty-cycle waveform
- WatchDog
  - 32 bits watchdog counter width

- Counter clock is from APB bus clock
- Counter counts down from a preset value to 0 to indicate the occurrence of a timeout
- WDT can perform two types of operations when timeout occurs:
  - ◆ Generate a system reset
  - ◆ First generate an interrupt and if this is not cleared by the service routine by the time a second timeout occurs then generate a system reset
- Programmable reset pulse length
- Totally 16 defined-ranges of main timeout period
- Bus Architecture
  - 128bit/64-bit/32-bit multi-layer AXI/AHB/APB composite bus architecture
  - Five embedded AXI interconnect:
    - ◆ BUS interconnect
    - ◆ PERI interconnect
    - ◆ Display interconnect
    - ◆ GPU interconnect
    - ◆ VCODEC interconnect
  - For each interconnect with AXI/AHB/APB composite bus, clocks for AXI/AHB/APB domains are always synchronous, and different integer ratio is supported for them.
  - Flexible different QoS solution to improve the utility of bus bandwidth
- Interrupt Controller
  - Support 3 PPI interrupt source and 128 SPI interrupt sources input from different components
  - Support 16 software-triggered interrupts
  - Input interrupt level is fixed, only high-level sensitive
  - Support different interrupt priority for each interrupt source, and they are always software-programmable
- DMAC
  - Micro-code programming based DMA
  - The specific instruction set provides flexibility for programming DMA transfers
  - Linked list DMA function is supported to complete scatter-gather transfer
  - Support internal instruction cache
  - Embedded DMA manager thread
  - Support data transfer types with memory-to-memory, memory-to-peripheral, peripheral-to-memory
  - Signals the occurrence of various DMA events using the interrupt output signals
  - Mapping relationship between each channel and different interrupt outputs is software-programmable
  - dmac configuration:
    - ◆ 8 channels totally
    - ◆ 13 hardware request from peripherals
    - ◆ 2 interrupt output

### 1.1.5 Video CODEC

- Embedded memory management unit(MMU)
- Video Decoder
  - Real-time video decoder of MPEG-1, MPEG-2, MPEG-4, H.263, H.264, MVC
  - Error detection and concealment support for all video formats
  - Output data format is YUV420 semi-planar, and YUV400(monochrome) is also supported for H.264
  - H.264 up to HP level 4.2 : 1080p@30fps (1920x1088)<sup>®</sup>
  - H.265 up to main 4.1 : 1080p@30fps (1920x1088)
  - MPEG-4 up to ASP level 5 : 1080p@30fps (1920x1088)
  - MPEG-2 up to MP : 1080p@30fps (1920x1088)
  - MPEG-1 up to MP : 1080p@30fps (1920x1088)

- H.263 : 576p@30fps (720x576)
- MVC : 1080p@30fps (1920x1088)
- For H.264, image cropping not supported
- For MPEG-4, GMC(global motion compensation) not supported
- For MPEG-4 SP/H.263, using a modified H.264 in-loop filter to implement deblocking filter in post-processor unit

### **1.1.6 JPEG CODEC**

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

### **1.1.7 Image Enhancement**

- Image Post-Processor (embedded inside video decoder)
  - Combined with HD video decoder and JPEG decoder, post-processor can read input data directly from decoder output to reduce bus bandwidth
  - Also work as a stand-alone mode, its input data is from image data stored in external memory
  - Input data format:
    - ◆ Any format generated by video decoder in combined mode
    - ◆ YCbCr 4:2:0 semi-planar
    - ◆ YCbCr 4:2:0 planar
    - ◆ YCbYCr 4:2:2
    - ◆ YCrYCb 4:2:2
    - ◆ CbYCrY 4:2:2
    - ◆ CrYCbY 4:2:2
  - Output data format:
    - ◆ YCbCr 4:2:0 semi-planar
    - ◆ YCbYCr 4:2:2
    - ◆ YCrYCb 4:2:2
    - ◆ CbYCrY 4:2:2
    - ◆ CrYCbY 4:2:2
    - ◆ Fully configurable ARGB channel lengths and locations inside 32bits, such as ARGB8888, RGB565, ARGB4444 etc.
  - Input image size:
    - ◆ Combined mode: from 48x48 to 8176x8176 (66.8Mpixels)
    - ◆ Stand-alone mode: width from 48 to 8176, height from 48 to 8176, and maximum size limited to 16.7Mpixels
    - ◆ Step size is 16 pixels
  - Output image size: from 16x16 to 1920x1088 (horizontal step size 8, vertical step size 2)
  - Support image up-scaling:
    - ◆ Bicubic polynomial interpolation with a four-tap horizontal kernel and a two-tap vertical kernel
    - ◆ Arbitrary non-integer scaling ratio separately for both dimensions
    - ◆ Maximum output width is 3x input width
    - ◆ Maximum output height is 3x input height
  - Support image down-scaling:
    - ◆ Arbitrary non-integer scaling ratio separately for both dimensions
    - ◆ Unlimited down-scaling ratio
  - Support YUV to RGB color conversion, compatible with BT.601-5, BT.709 and user

- definable conversion coefficient
- Support dithering (Allegro dithering algorithm) for 4/5/6bit RGB channel precision
- Support RGB image contrast/brightness/color saturation adjustment
- Support image cropping & digital zoom only for JPEG or stand-alone mode
- Support picture in picture
- Support image rotation (horizontal flip, vertical flip, rotation 90, 180 or 270 degrees)

### 1.1.8 Graphics Engine

- 3D Graphics Engine(GPU)
  - High performance OpenGL ES1.1 and 2.0, OpenVG1.1 etc.
  - Embedded 1 shader core with shared hierarchical tiler
  - Separate vertex(geometry) and fragment(pixel) processing for maximum parallel throughput
  - Provide MMU and L2 Cache with 64KB size

### 1.1.9 Video OUT

- Display Interface
  - Display process
    - ◆ Background layer
      - programmable 24-bit color
    - ◆ Win0 (Video) layer
      - RGB888, ARGB888, RGB565, YCbCr422, YCbCr420, YCbCr444
      - Support virtual display
      - 1/8 to 8 scaling-down and scaling-up engine
        - ✧ Scale up using bicubic or bilinear
        - ✧ Scale down using bilinear
        - ✧ 1 Bicubic table: catrom
        - ✧ coord 8bit, coe 8bit signed
    - ◆ Win1 (UI) layer:
      - RGB888, ARGB888, RGB565
      - Support virtual display
    - ◆ Hardware cursor:
      - 8bpp
      - Support two sizes: 32x32,64x64
    - ◆ Overlay:
      - Win0/Win1 256 level alpha blending (support pre-multiplied alpha)
      - Win0/Win1 overlay position exchangeable
      - Win0/Win1 Transparency color key
      - Win0/Win1 global/per-pixel alpha
      - HWC 256 level alpha blending
      - HWC global/per-pixel alpha
    - Others
      - ◆ Max output resolution: 1920x1080
      - ◆ Max scanning timing: 4096x4096
      - ◆ YcbCr2RGB(rec601-mpeg/rec601-jpeg/rec709)and RGB2YcbCr
      - ◆ Support BCSH function
      - ◆ QoS request signals
      - ◆ Bus address alignment
      - ◆ Embedded memory management unit(MMU)
  - HDMI TX
    - HDMI version 1.4a, HDCP revision 1.2 and DVI version 1.0 compliant transmitter
    - Supports DTV from 480i to 1080i/p HD resolution
    - Supports 3D function defined in HDMI 1.4 spec
    - Supports data rate up to 3.4Gbps over a Single channel HDMI
    - TMDS Tx Drivers with programmable output swing, register values and pre-emphasis

- Digital video interface supports a pixel size of 24 color depth in RGB
  - S/PDIF output supports PCM, Dolby Digital, DTS digital audio transmission (32-192kHz Fs) using IEC60958 and IEC61937
  - Multiphase 4MHz fixed bandwidth PLL with low jitter
  - HDCP encryption and decryption engine contains all the necessary logic to encrypt the incoming audio and video data
  - Support HDMI LipSync if needed
  - Lower power operation with optimal power management feature
  - The EDID and CEC function are also supported
  - Optional Monitor Detection supported through Hot Plug
  - Support 8-channel I2S and 8-channel SPDIF input
- Video CVBS output
    - 10-bit Resolution
    - PAL/NTSC encoding
    - Programmable luma filter coefficient
    - Programmable luma/chroma delay
    - Programmable brightness/contrast

### **1.1.10 Audio Interface**

- I2S/PCM with 8ch
  - Up to 8 channels (4xTX, 1xRX)
  - Audio resolution from 16bits to 32bits
  - Sample rate up to 192KHz
  - Provides master and slave work mode, software configurable
  - Support 3 I2S formats (normal, left-justified, right-justified)
  - Support 4 PCM formats(early, late1, late2, late3)
  - I2S and PCM mode cannot be used at the same time
- SPDIF
  - Up to 8 channels
  - Support two 16-bit audio data store together in one 32-bit wide location
  - Support biphase format stereo audio data output
  - Support 16 to 31 bit audio data left or right justified in 32-bit wide sample data buffer
  - Support 16, 20, 24 bits audio data transfer in linear PCM mode
  - Support non-linear PCM transfer
- Audio DAC
  - 24 bit audio DAC and line out buffer
  - Support Mono channel performance
  - Digital interpolation and decimation filter integrated
  - Sampling rate of 8kHz/12kHz/16kHz/24kHz/32kHz/44.1KHz/48KHz/96KHz
  - Optional fractional PLL available that support 6MHz to 20MHz clock input to any clock

### **1.1.11 Connectivity**

- SDIO interface
  - Embedded one SDIO interface
  - Compatible with SDIO 3.0 protocol
  - 4bits data bus widths
- EMAC 10/100M Ethernet Controller
  - IEEE802.3u compliant Ethernet Media Access Controller(MAC)
  - Support only RMII(Reduced MII) mode
  - 10Mbps and 100Mbps compatible
  - Automatic retry and automatic collision frame deletion
  - Full duplex support with flow-control

- Address filtering(broadcast, multicast, logical, physical)
- SPI Controller
  - One on-chip SPI controller
  - Support serial-master and serial-slave mode, software-configurable
  - DMA-based or interrupt-based operation
  - Support 2 chip-selects output in serial-master mode
- UART Controller
  - Three on-chip UART controller
  - DMA-based or interrupt-based operation
  - For all UART, UART0 is 64Bytes FIFOs, and the others are with 32Bytes FIFOs
  - Support 5bit,6bit,7bit,8bit serial data transmit or receive
  - Standard asynchronous communication bits such as start, stop and parity
  - Support different input clock for UART operation to get up to 4Mbps or other special baud rate
  - Support non-integer clock divides for baud clock generation
- I2C controller
  - Three on-chip I2C controller
  - Multi-master I2C operation
  - Support 7bits and 10bits address mode
  - Software programmable clock frequency and transfer rate up to 400Kbit/s in the fast mode
  - Serial 8bits oriented and bidirectional data transfers can be made at up to 100Kbit/s in the standard mode
- GPIO
  - Totally 70 GPIOs
  - All of GPIOs can be used to generate interrupt to Cortex-A7
  - The pull direction(pullup or pulldown) for all of GPIOs are software-programmable
  - All of GPIOs are always in input direction in default after power-on-reset
  - The drive strength is not software-programmable, determined by the GPIO type
- USB Host2.0
  - Compatible with USB Host2.0 specification
  - Supports high-speed(480Mbps), full-speed(12Mbps) and low-speed (1.5Mbps) mode
  - Provides 16 host mode channels
  - Support periodic out channel in host mode
- USB OTG2.0
  - Compatible with USB OTG2.0 specification
  - Supports high-speed(480Mbps), full-speed(12Mbps) and low-speed (1.5Mbps) mode
  - Support up to 9 device mode endpoints in addition to control endpoint 0
  - Support up to 6 device mode IN endpoints including control endpoint 0
  - Endpoints 1/3/5/7 can be used only as data IN endpoint
  - Endpoints 2/4/6 can be used only as data OUT endpoint
  - Endpoints 8/9 can be used as data OUT and IN endpoint
  - Provides 9 host mode channels

### 1.1.12 Others

- eFuse
  - One 256bits high-density electrical Fuse, organized as 32x8bits
  - Program 1-bit each time in program mode
  - Read 8-bit each time in read mode
  - Three operation modes: program mode, read mode, inactive mode

- Package Type
  - eLQFP176 (body: 20mm x 20mm; pin pitch: 0.4mm)
  - BGA236(body: 12mm x 12mm; pin pitch: 0.65mm)

**Notes:**

- ① Actual maximum frame rate will depend on the clock frequency and system bus performance
- ④ Actual maximum data rate will depend on the clock frequency and JPEG compression rate

## 1.2 Block Diagram

The following diagram shows the basic block diagram for RK3036.



Fig. 1-1 RK3036 Block Diagram

## Chapter 2 System Overview

### 2.1 Address Mapping

RK3036 supports to boot from internal bootrom, which supports remap function by software programming. Remap is controlled by GRF\_SOC\_CON0[12]. When remap is set to 1, the bootrom is mapped to address 0x10100000 and internal memory is mapped to address 0x0.

| Addr     | IP            | Addr     | IP             | Addr     | IP             | Addr     | IP           |
|----------|---------------|----------|----------------|----------|----------------|----------|--------------|
| 1013e000 | Reserved      | 20038000 |                | 10504000 |                | 20094000 |              |
| 1013d000 | Reserved 4K   | 20034000 | HDMI-ANA 16K   | 10500000 | NANDC 16K      | 20090000 | eFuse 16K    |
| 1013c000 | Reserved 8k   | 20030000 | ACODEC-ANA 16K | 10400000 | Reserved 1024K | 2008C000 | 16K          |
| 10138000 | GIC 16K       | 20020000 | DBG 64K        | 10300000 | PERI BUS 1024k | 20088000 | reserved 16K |
| 10130000 | Reserved 32K  | 20010000 | Reserved 64K   | 1023C000 | AHB ARB1 784K  | 20084000 | GPIO2 16K    |
| 10128000 | CPU BUS 32K   | 2000a000 | DDR_PHY 24K    | 10234000 | AHB ARBO 32K   | 20080000 | GPIO1 16K    |
| 10124000 | Reserved 16K  | 20008000 | GRF 8K         | 10224000 | Reserved 64K   | 2007C000 | GPIO 16K     |
| 10120000 | Reserved 16k  | 20004000 | DDR_PCTL 16K   | 10220000 | I2S 16K        | 20078000 | DMAC 16K     |
| 1011c000 | Reserved 8K   | 20000000 | CRU 16K        | 1021C000 | eMMC 16K       | 20074000 | SPI 16K      |
| 10118000 | VOP 16K       |          |                | 10218000 | SDIO 16K       | 20072000 | I2C0 8K      |
| 10114000 | Reserved 16K  |          |                | 10214000 | SDMMC 16K      | 2006C000 | Reserved 24K |
| 10110000 | Reserved 16K  |          |                | 1020C000 | Reserved 64k   | 20068000 | UART2 16K    |
| 1010c000 | Hevc 16K      |          |                | 10208000 | SFC 16k        | 20064000 | UART1 16K    |
| 10108000 | Vcodec 16K    |          |                | 10204000 | SPDIF 16K      | 20060000 | UART0 16K    |
| 10104000 | Reserved 16K  |          |                | 10200000 | EMAC 16K       | 2005C000 | reserved 16K |
| 10100000 | ROM 16K       |          |                | 101C0000 | USB HOST 256K  | 2005a000 | I2C2 8K      |
| 100a0000 | Reserved 384K |          |                | 10180000 | USB OTG 256K   | 20056000 | I2C1 16K     |
| 10090000 | GPU 64K       |          |                |          |                | 20050000 | PWM 24K      |
| 10082000 | Reserved 56K  |          |                |          |                | 2004C000 | WDT 16K      |
| 10080000 | IMEM 8K       |          |                |          |                | 20048000 | Reserved 16K |

Fig. 2-1 RK3036 Address Mapping

### 2.2 System Boot

RK3036 provides system boot from off-chip devices such as SDMMC card, eMMC memory, 8bits asynchronous nand flash, serial nand or nor flash. When boot code is not ready in these devices, also provide system code download into them by USB OTG interface. All of the boot code will be stored in internal bootrom. The following is the whole boot procedure for boot code, which will be stored in bootrom in advance.

The following features are supports.

- Support secure boot mode and non-secure boot mode
- Support system boot from the following device:
  - Asynchronous Nand Flash, 8bits data width
  - Serial Nand Flash/SPI Nand Flash, 1bit data width
  - Serial Nor Flash, 1bit data width
  - eMMC Interface, 8bits data width
  - SDMMC Card, 4bits data width
- Support system code download by USB OTG

Following figure shows RK3036 boot procedure flow.



Fig. 2-2 RK3036 boot procedure flow

## 2.3 System Interrupt connection

RK3036 provides an general interrupt controller(GIC) for CPU, which has 128 SPI (shared peripheral interrupts) interrupt sources and 3 PPI(Private peripheral interrupt) interrupt source and separately generates one nIRQ and one nFIQ to CPU. The triggered type for each

interrupts is high level sensitive, not programmable. The detailed interrupt sources connection is in the following table. For detailed GIC setting, please refer to Chapter 9.

Table 2-1 RK3036 Interrupt connection list

| IRQ Type | IRQ ID | Source(spi)    | Polarity   |
|----------|--------|----------------|------------|
| PPI      | 27     | Golbal Timer   | High level |
|          | 29     | Private Timer  | High level |
|          | 30     | WDT            | High level |
| SPI      | 32     | DMAC2(0)       | High level |
|          | 33     | DMAC2(1)       | High level |
|          | 34     | DDR_PCTL       | High level |
|          | 35     | gpu_irqgp      | High level |
|          | 36     | gpu_irqmmu     | High level |
|          | 37     | gpu_irqpp      | High level |
|          | 38     | Video encoder  | High level |
|          | 39     | Video decoder  | High level |
|          | 40     | EMAC           | High level |
|          | 41     | SFC            | High level |
|          | 42     | USB OTG        | High level |
|          | 43     | USB Host2.0    | High level |
|          | 44     | Reserved       | High level |
|          | 45     | Reserved       | High level |
|          | 46     | SD/MMC0        | High level |
|          | 47     | SDIO           | High level |
|          | 48     | eMMC           | High level |
|          | 49     | Reserved       | High level |
|          | 50     | NandC          | High level |
|          | 51     | I2S            | High level |
|          | 52     | UART0          | High level |
|          | 53     | UART1          | High level |
|          | 54     | UART2          | High level |
|          | 55     | SPI0           | High level |
|          | 56     | I2C0           | High level |
|          | 57     | I2C1           | High level |
|          | 58     | I2C2           | High level |
|          | 59     | Reserved       | High level |
|          | 60     | Timer0         | High level |
|          | 61     | Timer1         | High level |
|          | 62     | PWM            | High level |
|          | 63     | Reserved       | High level |
|          | 64     | Reserved       | High level |
|          | 65     | Reserved       | High level |
|          | 66     | WDT            | High level |
|          | 67     | otg_bvalid_irq | High level |
|          | 68     | GPIO0          | High level |
|          | 69     | GPIO1          | High level |

| IRQ Type | IRQ ID  | Source(spi)          | Polarity   |
|----------|---------|----------------------|------------|
|          | 70      | GPIO2                | High level |
|          | 71      | Reserved             | High level |
|          | 72      | Reserved             | High level |
|          | 73      | Reserved             | High level |
|          | 74      | peri_ahb_usb arbiter | High level |
|          | 75      | VOP                  | High level |
|          | 76      | Reserved             | High level |
|          | 77      | hdmi                 | High level |
|          | 78      | SD/MMC detect        | High level |
|          | 79      | SDIO detect          | High level |
|          | 80      | Reserved             | High level |
|          | 81      | Reserved             | High level |
|          | 82      | Reserved             | High level |
|          | 83      | otg0_id_irq          | High level |
|          | 84      | otg0_linestate_irq   | High level |
|          | 85      | otg1_linestate_irq   | High level |
|          | 86      | sd_detectn_irq       | High level |
|          | 87      | VPU_mmu_irq          | High level |
|          | 88      | Hevc_mmu_irq         | High level |
|          | 89      | Hevc_dec_irq         | High level |
|          | 90      | Timer2               | High level |
|          | 91      | Timer3               | High level |
|          | 92      | SPDIF                | High level |
|          | 93      | Reserved             | High level |
|          | 94      | Reserved             | High level |
|          | 95      | Reserved             | High level |
|          | 96      | Reserved             | High level |
|          | 97      | Reserved             | High level |
|          | 98      | Reserved             | High level |
|          | 99      | Reserved             | High level |
|          | 100     | Reserved             | High level |
|          | 101     | Reserved             | High level |
|          | 102     | Reserved             | High level |
|          | 103     | Reserved             | High level |
|          | 104     | Reserved             | High level |
|          | 105     | Reserved             | High level |
|          | 106     | Reserved             | High level |
|          | 107     | Reserved             | High level |
|          | 108     | core_npmuirq0        | High level |
|          | 109     | core_npmuirq1        | High level |
|          | 110     | core_npmuirq2        | High level |
|          | 111     | core_npmuirq3        | High level |
|          | 112     | axierrirq            | High level |
|          | 113~159 | Reserved             | High level |

## 2.4 System DMA hardware request connection

RK3036 provides one DMA controller: DMAC\_PERI inside peripheral system. As for DMAC\_PERI, there are 14 hardware request ports. The trigger type for each of them is high level, not programmable. For detailed descriptions of DMAC\_PERI, please refer to Chapter 8.

Table 2-2 RK3036 DMAC\_PERI Hardware request connection list

| Req Number | Source   | Polarity   |
|------------|----------|------------|
| 0          | I2S tx   | High level |
| 1          | I2S rx   | High level |
| 2          | Uart0 tx | High level |
| 3          | Uart0 rx | High level |
| 4          | Uart1 tx | High level |
| 5          | Uart1 rx | High level |
| 6          | Uart2 tx | High level |
| 7          | Uart2 rx | High level |
| 8          | SPI tx   | High level |
| 9          | SPI rx   | High level |
| 10         | SDMMC    | High level |
| 11         | SDIO     | High level |
| 12         | EMMC     | High level |
| 13         | SPDIF tx | High level |

## Chapter 3 Clock & Reset Unit (CRU)

### 3.1 Overview

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

CRU supports the following features:

- Compliance to the AMBA APB interface
- Embedded three PLLs
- Flexible selection of clock source
- Supports the respective gating of all clocks
- Supports the respective software reset of all modules

### 3.2 Block Diagram

The CRU comprises with:

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



Fig. 3-1 CRU Architecture

### 3.3 System Reset Solution

The following diagram shows reset architecture.



Fig. 3-2 Reset Architecture Diagram

Reset source of each reset signal includes hardware reset(NPOR), SoC watch dog reset(soc\_wdt\_rstn), software reset request(xxx\_softrstn\_req), global software reset1(glb\_srstn\_1), global software reset2(glb\_srstn\_2) and A7 core watch dog reset(core\_wdt\_rstn).

The 'xxx' of resetn\_xxx and xxx\_softrstn\_req is the module name.

soc\_wdt\_rstn is the reset from watch-dog IP in the SoC, but core\_wdt\_rstn is the reset from A7 core watch-dog block.

glb\_srstn\_1 and glb\_srstn\_2 are the global software reset by programming CRU register. When writing register CRU\_GLB\_SRST\_FST\_VALUE as 0xfd9, glb\_srstn\_1 will be asserted, and when writing register CRU\_GLB\_SRST\_SND\_VALUE as 0xea8, glb\_srstn\_2 will be asserted. The two software resets will be self-cleared by hardware. glb\_srstn\_1 will reset the all logic, and glb\_srstn\_2 will reset the all logic except GRF and all GPIOs.

## 3.4 Function Description

There are three PLLs in the chip: ARM PLL, DDR PLL and GENERAL PLL, and it supports only one crystal oscillator: 24MHz. Each PLL can only receive 24MHz oscillator.

Three PLLs all can be set to slow mode or deep slow mode, directly output selectable 24MHz. When power on or changing PLL setting, we must force PLL into slow mode to ensure output stable clock.

To maximize the flexibility, some of clocks can select divider source from three PLLs.

To provide some specific frequency, another solution is integrated: fractional divider. In order to guarantee the performance for divided clock, there is some usage limit, we can only get low frequency and divider factor must be larger than 20.

All clocks can be software gated and all resets can be software generated.

## 3.5 PLL Introduction

### 3.5.1 Overview

The chip uses 2.4GHz PLL for all three PLLs. The 2.4GHz PLL is a general purpose, high-performance PLL-based clock generator. The PLL is a multi-function, general purpose frequency synthesizer. Ultra-wide input and output ranges along with best-in-class jitter performance allow the PLL to be used for almost any clocking application. With excellent supply noise immunity, the PLL is ideal for use in noisy mixed signal SoC environments. By combining ultra-low jitter output clocks into a low power, low area, widely programmable design, we can greatly simplify an SoC by enabling a single macro to be used for all clocking applications in the system.

2.4GHz PLL supports the following features:

- Input frequency range: 1MHz to 800MHz (Integer Mode) and 10MHz to 800MHz (Fractional Mode)
- Output Frequency Range: 12MHz to 2.4GHz
- 24 bit fractional accuracy, and fractional mode jitter performance to nearly match integer mode performance.
- 4:1 VCO frequency range allows PLL to be optimized for minimum jitter or minimum power.
- Isolated analog supply (2.5V) allows for excellent supply rejection in noisy SoC applications.
- Lock Detect Signal indicates when frequency lock has been achieved.

### 3.5.2 Block diagram



Fig. 3-3 PLL Block Diagram

#### How to calculate the PLL

The Fractional PLL output frequency can be calculated using some simple formulas. These formulas also embedded within the Fractional PLL Verilog model:

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

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

$$\text{FOUTPOSTDIV} = \text{FOUTVCO} / \text{POSTDIV1} / \text{POSTDIV2}$$

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

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

$$\text{FOUTPOSTDIV} = \text{FOUTVCO} / \text{POSTDIV1} / \text{POSTDIV2}$$

Where:

FOUTVCO = Fractional PLL non-divided output frequency

FOUTPOSTDIV = Fractional PLL divided output frequency (output of second post divider)

FREF = Fractional PLL input reference frequency

REFDIV = Fractional PLL input reference clock divider

FVCO = Frequency of internal VCO

FBDIV = Integer value programmed into feedback divide

FRAC = Fractional value programmed into DSM

#### Changing the PLL Programming

In most cases the PLL programming can be changed on-the-fly and the PLL will simply slew to the new frequency. However, certain changes have the potential to cause glitches on the PLL output clocks. These changes include:

- Switching into or out of BYPASS mode may cause a glitch on FOUTPOSTDIV
- Changing POSTDIV1 or POSTDIV2 may cause a short pulse with width equal to as little as one VCO period on FOUTPOSTDIV
- Changing POSTDIV could cause a shortened pulse on FOUT1PH\* or FOUT2/3/4
- Asserting PD or FOUTPOSTDIVPD may cause a glitch on FOUTPOSTDIV

## 3.6 Register Description

This section describes the control/status registers of the design.

### 3.6.1 Registers Summary

| Name          | Offset | Size | Reset Value | Description                |
|---------------|--------|------|-------------|----------------------------|
| CRU_APPL_CON0 | 0x0000 | W    | 0x000010af  | ARM PLL control register 0 |
| CRU_APPL_CON1 | 0x0004 | W    | 0x00001046  | ARM PLL control register 1 |

| Name             | Offset | Size | Reset Value | Description                                  |
|------------------|--------|------|-------------|----------------------------------------------|
| CRU_APLL_CON2    | 0x0008 | W    | 0x00000001  | ARM PLL control register 2                   |
| CRU_DPLL_CON0    | 0x0010 | W    | 0x00001064  | DDR PLL control register 0                   |
| CRU_DPLL_CON1    | 0x0014 | W    | 0x00001043  | DDR PLL control register 1                   |
| CRU_DPLL_CON2    | 0x0018 | W    | 0x00000001  | DDR PLL control register 2                   |
| CRU_GPLL_CON0    | 0x0030 | W    | 0x00004063  | General PLL control register 0               |
| CRU_GPLL_CON1    | 0x0034 | W    | 0x00001042  | General PLL control register 1               |
| CRU_GPLL_CON2    | 0x0038 | W    | 0x00f5c28f  | General PLL control register 2               |
| CRU_MODE_CON     | 0x0040 | W    | 0x00000000  | System work mode control register            |
| CRU_CLKSEL0_CON  | 0x0044 | W    | 0x00000200  | Internal clock select and divide register 0  |
| CRU_CLKSEL1_CON  | 0x0048 | W    | 0x00003113  | Internal clock select and divide register 1  |
| CRU_CLKSEL2_CON  | 0x004c | W    | 0x00000000  | Internal clock select and divide register 2  |
| CRU_CLKSEL3_CON  | 0x0050 | W    | 0x00008200  | Internal clock select and divide register 3  |
| CRU_CLKSEL5_CON  | 0x0058 | W    | 0x00000800  | Internal clock select and divide register 5  |
| CRU_CLKSEL7_CON  | 0x0060 | W    | 0x0bb8ea60  | Internal clock select and divide register 7  |
| CRU_CLKSEL9_CON  | 0x0068 | W    | 0x0bb8ea60  | Internal clock select and divide register 9  |
| CRU_CLKSEL10_CON | 0x006c | W    | 0x0000a100  | Internal clock select and divide register 10 |
| CRU_CLKSEL11_CON | 0x0070 | W    | 0x00001717  | Internal clock select and divide register 11 |
| CRU_CLKSEL12_CON | 0x0074 | W    | 0x00002a17  | Internal clock select and divide register 12 |
| CRU_CLKSEL13_CON | 0x0078 | W    | 0x00000200  | Internal clock select and divide register 13 |
| CRU_CLKSEL14_CON | 0x007c | W    | 0x00000200  | Internal clock select and divide register 14 |
| CRU_CLKSEL15_CON | 0x0080 | W    | 0x00000200  | Internal clock select and divide register 15 |
| CRU_CLKSEL16_CON | 0x0084 | W    | 0x00000202  | Internal clock select and divide register 16 |
| CRU_CLKSEL17_CON | 0x0088 | W    | 0x0bb8ea60  | Internal clock select and divide register 17 |
| CRU_CLKSEL18_CON | 0x008c | W    | 0x0bb8ea60  | Internal clock select and divide register 18 |
| CRU_CLKSEL19_CON | 0x0090 | W    | 0x0bb8ea60  | Internal clock select and divide register 19 |
| CRU_CLKSEL20_CON | 0x0094 | W    | 0x00000002  | Internal clock select and divide register 20 |

| <b>Name</b>            | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>                            |
|------------------------|---------------|-------------|--------------------|-----------------------------------------------|
| CRU_CLKSEL21_CON       | 0x0098        | W           | 0x00000012         | Internal clock select and divide register 21  |
| CRU_CLKSEL25_CON       | 0x00a8        | W           | 0x00000207         | Internal clock select and divide register 25  |
| CRU_CLKSEL26_CON       | 0x00ac        | W           | 0x00000000         | Internal clock select and divide register 26  |
| CRU_CLKSEL28_CON       | 0x00b4        | W           | 0x00000702         | Internal clock select and divide register 28  |
| CRU_CLKSEL30_CON       | 0x00bc        | W           | 0x00008300         | Internal clock select and divide register 30  |
| CRU_CLKSEL31_CON       | 0x00c0        | W           | 0x00008000         | Internal clock select and divide register 31  |
| CRU_CLKSEL32_CON       | 0x00c4        | W           | 0x00008000         | Internal clock select and divide register 32  |
| CRU_CLKSEL34_CON       | 0x00cc        | W           | 0x00000200         | Internal clock select and divide register 34  |
| CRU_CLKGATE0_CON       | 0x00d0        | W           | 0x00000000         | Internal clock gating control register 0      |
| CRU_CLKGATE1_CON       | 0x00d4        | W           | 0x00000000         | Internal clock gating control register 1      |
| CRU_CLKGATE2_CON       | 0x00d8        | W           | 0x00000000         | Internal clock gating control register 2      |
| CRU_CLKGATE3_CON       | 0x00dc        | W           | 0x00000000         | Internal clock gating control register 3      |
| CRU_CLKGATE4_CON       | 0x00e0        | W           | 0x00000000         | Internal clock gating control register 4      |
| CRU_CLKGATE5_CON       | 0x00e4        | W           | 0x00000000         | Internal clock gating control register 5      |
| CRU_CLKGATE6_CON       | 0x00e8        | W           | 0x00000000         | Internal clock gating control register 6      |
| CRU_CLKGATE7_CON       | 0x00ec        | W           | 0x00000000         | Internal clock gating control register 7      |
| CRU_CLKGATE8_CON       | 0x00f0        | W           | 0x00000000         | Internal clock gating control register 8      |
| CRU_CLKGATE9_CON       | 0x00f4        | W           | 0x00000000         | Internal clock gating control register 9      |
| CRU_CLKGATE10_CON      | 0x00f8        | W           | 0x00000000         | Internal clock gating control register 10     |
| CRU_GLB_SRST_FST_VALUE | 0x0100        | W           | 0x00000000         | The first global software reset config value  |
| CRU_GLB_SRST SND_VAL   | 0x0104        | W           | 0x00000000         | The second global software reset config value |
| CRU_SOFRST0_CON        | 0x0110        | W           | 0x00000000         | Internal software reset control register 0    |

| Name             | Offset | Size | Reset Value | Description                                |
|------------------|--------|------|-------------|--------------------------------------------|
| CRU_SOFRST1_CON  | 0x0114 | W    | 0x00000000  | Internal software reset control register 1 |
| CRU_SOFRST2_CON  | 0x0118 | W    | 0x00000000  | Internal software reset control register 2 |
| CRU_SOFRST3_CON  | 0x011c | W    | 0x00000000  | Internal software reset control register 3 |
| CRU_SOFRST4_CON  | 0x0120 | W    | 0x00000000  | Internal software reset control register 4 |
| CRU_SOFRST5_CON  | 0x0124 | W    | 0x00000000  | Internal software reset control register 5 |
| CRU_SOFRST6_CON  | 0x0128 | W    | 0x00000000  | Internal software reset control register 6 |
| CRU_SOFRST7_CON  | 0x012c | W    | 0x00000000  | Internal software reset control register 7 |
| CRU_SOFRST8_CON  | 0x0130 | W    | 0x00000000  | Internal software reset control register 8 |
| CRU_MISC_CON     | 0x0134 | W    | 0x00000000  | SCU control register                       |
| CRU_GLB_CNT_TH   | 0x0140 | W    | 0x3a980064  | global reset wait counter threshold        |
| CRU_SDMMC_CON0   | 0x0144 | W    | 0x00000004  | SDMMC clock generation control register 0  |
| CRU_SDMMC_CON1   | 0x0148 | W    | 0x00000000  | SDMMC clock generation control register 1  |
| CRU_SDIO_CON0    | 0x014c | W    | 0x00000004  | SDIO clock generation control register 0   |
| CRU_SDIO_CON1    | 0x0150 | W    | 0x00000000  | SDIO clock generation control register 1   |
| CRU_EMMC_CON0    | 0x0154 | W    | 0x00000004  | EMMC clock generation control register 0   |
| CRU_EMMC_CON1    | 0x0158 | W    | 0x00000000  | EMMC clock generation control register 1   |
| CRU_RST_ST       | 0x0160 | W    | 0x00000000  | WDT and global reset status                |
| CRU_PLL_MASK_CON | 0x01f0 | W    | 0x00005a5a  | PLL mask control register                  |

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

### 3.6.2 Detail Register Description

#### CRU\_APPL\_CON0

Address: Operational Base + offset (0x0000)

ARM PLL control register 0

| Bit   | Attr | Reset Value | Description                                                                                                               |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0x0000      | bit_write_mask<br>bit_write_mask control corresponding (bit_write_mask - 16)<br>configuration bit<br>0: mask<br>1: unmask |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>              |
|------------|-------------|--------------------|---------------------------------|
| 15         | RW          | 0x0                | bp<br>PLL bypass                |
| 14:12      | RW          | 0x1                | postdiv1<br>PLL factor postdiv1 |
| 11:0       | RW          | 0x0af              | fbdv<br>PLL factor fbdv         |

**CRU\_APPL\_CON1**

Address: Operational Base + offset (0x0004)

ARM PLL control register 1

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | bit_write_mask<br>bit_write_mask control corresponding (bit_write_mask - 16)<br>configuration bit<br>0: mask<br>1: unmask |
| 15         | RW          | 0x0                | rstmode<br>PLL Reset select<br>0 : internal reset<br>1 : software reset                                                   |
| 14         | RW          | 0x0                | rst<br>PLL Software Reset<br>0 : normal<br>1 : reset                                                                      |
| 13         | RW          | 0x0                | pd<br>PLL software power down, active high                                                                                |
| 12         | RW          | 0x1                | dsmpd<br>when 1, PLL work at interger mode<br>when 0, PLL work at frac mode                                               |
| 11         | RO          | 0x0                | reserved                                                                                                                  |
| 10         | RW          | 0x0                | lock<br>PLL lock status                                                                                                   |
| 9          | RO          | 0x0                | reserved                                                                                                                  |
| 8:6        | RW          | 0x1                | postdiv2<br>PLL factor postdiv2                                                                                           |
| 5:0        | RW          | 0x06               | refdiv<br>PLL factor refdiv                                                                                               |

**CRU\_APPL\_CON2**

Address: Operational Base + offset (0x0008)

ARM PLL control register 2

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                    |
|------------|-------------|--------------------|-------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                              |
| 27         | RW          | 0x0                | fout4phasepd<br>4 phase clock power down, active high |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                      |
|------------|-------------|--------------------|---------------------------------------------------------|
| 26         | RW          | 0x0                | foutvcopd<br>buffered VCO clock power down, active high |
| 25         | RW          | 0x0                | foutpostdivpd<br>post divide power down, active high    |
| 24         | RW          | 0x0                | dacpd<br>PLL cancellation DAC power down, active high   |
| 23:0       | RW          | 0x000001           | frac<br>PLL factor frac                                 |

**CRU\_DPLL\_CON0**

Address: Operational Base + offset (0x0010)

DDR PLL control register 0

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | bit_write_mask<br>bit_write_mask control corresponding (bit_write_mask - 16)<br>configuration bit<br>0: mask<br>1: unmask |
| 15         | RW          | 0x0                | bp<br>pll bypass                                                                                                          |
| 14:12      | RW          | 0x1                | postdiv1<br>PLL factor postdiv1                                                                                           |
| 11:0       | RW          | 0x064              | fbdv<br>PLL factor fbdv                                                                                                   |

**CRU\_DPLL\_CON1**

Address: Operational Base + offset (0x0014)

DDR PLL control register 1

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | bit_write_mask<br>bit_write_mask control corresponding (bit_write_mask - 16)<br>configuration bit<br>0: mask<br>1: unmask |
| 15         | RW          | 0x0                | rstmode<br>PLL Reset select<br>0 : internal reset<br>1 : software reset                                                   |
| 14         | RW          | 0x0                | rst<br>PLL Software Reset<br>0 : normal<br>1 : reset                                                                      |
| 13         | RW          | 0x0                | pd<br>PLL software power down, active high                                                                                |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------|
| 12         | RW          | 0x1                | dsmpd<br>when 1, PLL work at integer mode<br>when 0, PLL work at frac mode |
| 11         | RO          | 0x0                | reserved                                                                   |
| 10         | RW          | 0x0                | lock<br>PLL lock status                                                    |
| 9          | RO          | 0x0                | reserved                                                                   |
| 8:6        | RW          | 0x1                | postdiv2<br>PLL factor postdiv2                                            |
| 5:0        | RW          | 0x03               | refdiv<br>PLL factor refdiv                                                |

**CRU\_DPLL\_CON2**

Address: Operational Base + offset (0x0018)

DDR PLL control register 2

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                      |
|------------|-------------|--------------------|---------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                |
| 27         | RW          | 0x0                | fout4phasepd<br>4 phase clock power down, active high   |
| 26         | RW          | 0x0                | foutvcopd<br>buffered VCO clock power down, active high |
| 25         | RW          | 0x0                | foutpostdivpd<br>post divide power down, active high    |
| 24         | RW          | 0x0                | dacpd<br>PLL cancellation DAC power down, active high   |
| 23:0       | RW          | 0x000001           | frac<br>PLL factor frac                                 |

**CRU\_GPLL\_CON0**

Address: Operational Base + offset (0x0030)

General PLL control register 0

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | bit_write_mask<br>bit_write_mask control corresponding (bit_write_mask - 16)<br>configuration bit<br>0: mask<br>1: unmask |
| 15         | RW          | 0x0                | bp<br>pll bypass                                                                                                          |
| 14:12      | RW          | 0x4                | postdiv1<br>PLL factor postdiv1                                                                                           |
| 11:0       | RW          | 0x063              | fbdv<br>PLL factor fbdv                                                                                                   |

**CRU\_GPLL\_CON1**

Address: Operational Base + offset (0x0034)

General PLL control register 1

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | bit_write_mask<br>bit_write_mask control corresponding (bit_write_mask - 16)<br>configuration bit<br>0: mask<br>1: unmask |
| 15         | RW          | 0x0                | rstmode<br>PLL Reset select<br>0 : internal reset<br>1 : software reset                                                   |
| 14         | RW          | 0x0                | rst<br>PLL Software Reset<br>0 : normal<br>1 : reset                                                                      |
| 13         | RW          | 0x0                | pd<br>PLL software power down, active high                                                                                |
| 12         | RW          | 0x1                | dsmpd<br>when 1, PLL work at integer mode<br>when 0, PLL work at frac mode                                                |
| 11         | RO          | 0x0                | reserved                                                                                                                  |
| 10         | RW          | 0x0                | lock<br>PLL lock status                                                                                                   |
| 9          | RO          | 0x0                | reserved                                                                                                                  |
| 8:6        | RW          | 0x1                | postdiv2<br>PLL factor postdiv2                                                                                           |
| 5:0        | RW          | 0x02               | refdiv<br>PLL factor refdiv                                                                                               |

**CRU\_GPLL\_CON2**

Address: Operational Base + offset (0x0038)

General PLL control register 2

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                      |
|------------|-------------|--------------------|---------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                |
| 27         | RW          | 0x0                | fout4phasepd<br>4 phase clock power down, active high   |
| 26         | RW          | 0x0                | foutvcopd<br>buffered VCO clock power down, active high |
| 25         | RW          | 0x0                | foutpostdivpd<br>post divide power down, active high    |
| 24         | RW          | 0x0                | dacpd<br>PLL cancellation DAC power down, active high   |
| 23:0       | RW          | 0xf5c28f           | frac<br>PLL factor frac                                 |

**CRU\_MODE\_CON**

Address: Operational Base + offset (0x0040)

System work mode control register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                           |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 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:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                     |
| 13:12      | RW          | 0x0                | gpll_work_mode<br>General PLL work mode select<br>2'b00: Slow mode, clock from external 24MHz OSC (default)<br>2'b01: Normal mode, clock from PLL output<br>2'b10: Deep slow mode, clock from external 32.768kHz or PVTM clk |
| 11:5       | RO          | 0x0                | reserved                                                                                                                                                                                                                     |
| 4          | RW          | 0x0                | dpll_work_mode<br>DDR PLL work mode select<br>0: Slow mode, clock from external 24MHz OSC (default)<br>1: Normal mode, clock from PLL output                                                                                 |
| 3:1        | RO          | 0x0                | reserved                                                                                                                                                                                                                     |
| 0          | RW          | 0x0                | apll_work_mode<br>ARM PLL work mode select<br>0: Slow mode, clock from external 24MHz OSC (default)<br>1: Normal mode, clock from PLL output                                                                                 |

**CRU\_CLKSEL0\_CON**

Address: Operational Base + offset (0x0044)

Internal clock select and divide register 0

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 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:14      | RW          | 0x0                | cpu_clk_pll_sel<br>pd_cpu aclk_cpu pll source selection<br>2'b00: select ARM PLL<br>2'b01: select DDR PLL<br>2'b10: select GENERAL PLL  |
| 13         | RO          | 0x0                | reserved                                                                                                                                |
| 12:8       | RW          | 0x02               | aclk_cpu_div_con<br>aclk_cpu clock divider frequency<br>$aclk\_cpu = \text{cpu\_clk\_src} / (\text{aclk\_cpu\_div\_con} + 1)$           |
| 7          | RW          | 0x0                | core_clk_pll_sel<br>core clock pll source selection<br>1'b0: select ARM PLL<br>1'b1: select GENERAL PLL                                 |
| 6:5        | RO          | 0x0                | reserved                                                                                                                                |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------|
| 4:0        | RW          | 0x00               | a7_core_div_con<br>Control A7 core clock divider frequency<br>$\text{clk\_core} = \text{core\_clk\_src}/(\text{a7\_core\_div\_con}+1)$ |

**CRU\_CLKSEL1\_CON**

Address: Operational Base + offset (0x0048)

Internal clock select and divide register 1

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 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         | RO          | 0x0                | reserved                                                                                                                                           |
| 14:12      | RW          | 0x3                | cpu_pclk_div_con<br>Control cpu subsystem APB clock divider frequency<br>$\text{pclk\_cpu} = \text{cpu\_aclk\_src}/(\text{cpu\_pclk\_div\_con}+1)$ |
| 11:10      | RO          | 0x0                | reserved                                                                                                                                           |
| 9:8        | RW          | 0x1                | cpu_hclk_div_con<br>Control cpu subsystem AHB clock divider frequency<br>$\text{hclk\_cpu} = \text{cpu\_aclk\_src}/(\text{cpu\_hclk\_div\_con}+1)$ |
| 7          | RO          | 0x0                | reserved                                                                                                                                           |
| 6:4        | RW          | 0x1                | core_aclk_div_con<br>Control A7 core axi clock divider frequency<br>$\text{aclk\_core} = \text{core\_clk\_src}/(\text{core\_aclk\_div\_con}+1)$    |
| 3:0        | RW          | 0x3                | core_peri_div_con<br>core periph div control<br>$\text{clk\_core\_peri} = \text{clk\_peri\_src}/(\text{core\_peri\_div\_con}+1)$                   |

**CRU\_CLKSEL2\_CON**

Address: Operational Base + offset (0x004c)

Internal clock select and divide register 2

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 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:8       | RO          | 0x0                | reserved                                                                                                                                |
| 7          | RW          | 0x0                | clk_timer3_sel<br>timer3 clock select<br>1'b0: 24MHz<br>1'b1: pclk_peri                                                                 |
| 6          | RW          | 0x0                | clk_timer2_sel<br>timer2 clock select<br>1'b0: 24MHz<br>1'b1: pclk_peri                                                                 |

| Bit | Attr | Reset Value | Description                                                             |
|-----|------|-------------|-------------------------------------------------------------------------|
| 5   | RW   | 0x0         | clk_timer1_sel<br>timer1 clock select<br>1'b0: 24MHz<br>1'b1: pclk_peri |
| 4   | RW   | 0x0         | clk_timer0_sel<br>timer0 clock select<br>1'b0: 24MHz<br>1'b1: pclk_peri |
| 3:0 | RO   | 0x0         | reserved                                                                |

**CRU\_CLKSEL3\_CON**

Address: Operational Base + offset (0x0050)

Internal clock select and divide register 3

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                            |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 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:14 | RW   | 0x2         | i2s_pll_sel<br>2'b00: select ARM PLL<br>2'b01: select DDR PLL<br>2'b10: select GENERAL PLL                                                                                                                                             |
| 13    | RO   | 0x0         | reserved                                                                                                                                                                                                                               |
| 12    | RW   | 0x0         | i2s1_out_sel<br>1'b0: select cru generated clock<br>1'b1: select io input clock                                                                                                                                                        |
| 11:10 | RO   | 0x0         | reserved                                                                                                                                                                                                                               |
| 9:8   | RW   | 0x2         | i2s_clk_sel<br>Control I2S clock work frequency selection<br>2'b00: select divider output from pll divider<br>2'b01: select divider output from fraction divider<br>2'b10: select io input clock<br>2'b11: select 12MHz from osc input |
| 7     | RO   | 0x0         | reserved                                                                                                                                                                                                                               |
| 6:0   | RW   | 0x00        | i2s_pll_div_con<br>Control I2S PLL output divider frequency<br>$i2s1\_div\_clk = i2s1\_div\_src / (i2s1\_pll\_div\_con + 1)$                                                                                                           |

**CRU\_CLKSEL5\_CON**

Address: Operational Base + offset (0x0058)

Internal clock select and divide register 5

| Bit   | Attr | Reset Value | Description                                                                                                                             |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 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:12 | RO   | 0x0         | reserved                                                                                                                                |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11:10      | RW          | 0x2                | spdif_pll_sel<br>2'b00: select ARM PLL<br>2'b01: select DDR PLL<br>2'b10: select GENERAL PLL                                                               |
| 9:8        | RW          | 0x0                | spdif_clk_sel<br>2'b00: select divider output from pll divider<br>2'b01: select divider output from fraction divider<br>2'b10: select 12MHz from osc input |
| 7          | RO          | 0x0                | reserved                                                                                                                                                   |
| 6:0        | RW          | 0x00               | spdif_pll_div_con<br>clk_spdif_div_out=clk_spdif_src/(spdif_pll_div_con+1)                                                                                 |

**CRU\_CLKSEL7\_CON**

Address: Operational Base + offset (0x0060)

Internal clock select and divide register 7

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0xbb8ea60          | i2s_frac_factor<br>Control I2S fraction divider frequency<br>High 16-bit for numerator<br>Low 16-bit for denominator |

**CRU\_CLKSEL9\_CON**

Address: Operational Base + offset (0x0068)

Internal clock select and divide register 9

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0xbb8ea60          | spdif_frac_factor<br>Control I2S fraction divider frequency<br>High 16-bit for numerator<br>Low 16-bit for denominator |

**CRU\_CLKSEL10\_CON**

Address: Operational Base + offset (0x006c)

Internal clock select and divide register 10

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 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:14      | RW          | 0x2                | peri_pll_sel<br>Control peripheral clock PLL source selection<br>2'b00: select ARM PLL<br>2'b01: select DDR PLL<br>2'b10: select GENERAL PLL |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:12      | RW          | 0x2                | peri_pclk_div_con<br>Control the divider ratio between aclk_periph and pclk_periph<br>2'b00: aclk_periph:pclk_periph = 1:1<br>2'b01: aclk_periph:pclk_periph = 2:1<br>2'b10: aclk_periph:pclk_periph = 4:1<br>2'b11: aclk_periph:pclk_periph = 8:1 |
| 11:10      | RO          | 0x0                | reserved                                                                                                                                                                                                                                           |
| 9:8        | RW          | 0x1                | peri_hclk_div_con<br>Control the divider ratio between aclk_periph and hclk_periph<br>2'b00: aclk_periph:hclk_periph = 1:1<br>2'b01: aclk_periph:hclk_periph = 2:1<br>2'b10: aclk_periph:hclk_periph = 4:1                                         |
| 7:5        | RO          | 0x0                | reserved                                                                                                                                                                                                                                           |
| 4:0        | RW          | 0x00               | peri_aclk_div_con<br>Control peripheral clock divider frequency<br>aclk_periph=periph_clk_src/(peri_aclk_div_con+1)                                                                                                                                |

**CRU\_CLKSEL11\_CON**

Address: Operational Base + offset (0x0070)

Internal clock select and divide register 11

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 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         | RO          | 0x0                | reserved                                                                                                                                |
| 14:8       | RW          | 0x17               | sdio_div_con<br>Control SDIO divider frequency<br>clk_sdio0=general_pll_clk/(mmc0_div_con+1)                                            |
| 7          | RO          | 0x0                | reserved                                                                                                                                |
| 6:0        | RW          | 0x17               | mmc0_div_con<br>Control SDMMC0 divider frequency<br>clk_sdmmc0=general_pll_clk/(mmc0_div_con+1)                                         |

**CRU\_CLKSEL12\_CON**

Address: Operational Base + offset (0x0074)

Internal clock select and divide register 12

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 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:14      | RO          | 0x0                | reserved                                                                                                                                |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:12      | RW          | 0x2                | emmc_pll_sel<br>Control emmc clock PLL source selection<br>2'b00: select ARM PLL<br>2'b01: select DDR PLL<br>2'b10: select GENERAL PLL<br>2'b11: select X24M |
| 11:10      | RW          | 0x2                | sdio_pll_sel<br>Control sdio clock PLL source selection<br>2'b00: select ARM PLL<br>2'b01: select DDR PLL<br>2'b10: select GENERAL PLL<br>2'b11: select X24M |
| 9:8        | RW          | 0x2                | mmc0_pll_sel<br>Control sdio clock PLL source selection<br>2'b00: select ARM PLL<br>2'b01: select DDR PLL<br>2'b10: select GENERAL PLL<br>2'b11: select X24M |
| 7          | RO          | 0x0                | reserved                                                                                                                                                     |
| 6:0        | RW          | 0x17               | emmc_div_con<br>Control EMMC divider frequency<br>$\text{clk_emmc} = \text{general_pll_clk} / (\text{emmc\_div\_con} + 1)$                                   |

**CRU\_CLKSEL13\_CON**

Address: Operational Base + offset (0x0078)

Internal clock select and divide register 13

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 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:12      | RO          | 0x0                | reserved                                                                                                                                                                                                   |
| 11:10      | RW          | 0x0                | uart_pll_sel<br>Control UART clock PLL source selection<br>2'b00: select ARM PLL<br>2'b01: select DDR PLL<br>2'b10: select GENERAL PLL<br>2'b11: select usb_480m clock                                     |
| 9:8        | RW          | 0x2                | uart0_clk_sel<br>Control UART0 clock work frequency selection<br>2'b00: select divider output from pll divider<br>2'b01: select divider output from fraction divider<br>2'b10: select 24MHz from osc input |
| 7          | RO          | 0x0                | reserved                                                                                                                                                                                                   |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------|
| 6:0        | RW          | 0x00               | uart0_div_con<br>Control UART0 divider frequency<br>clk_uart0=uart_clk_src/(uart0_div_con+1) |

**CRU\_CLKSEL14\_CON**

Address: Operational Base + offset (0x007c)

Internal clock select and divide register 14

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 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:10      | RO          | 0x0                | reserved                                                                                                                                                                                                   |
| 9:8        | RW          | 0x2                | uart1_clk_sel<br>Control UART1 clock work frequency selection<br>2'b00: select divider output from pll divider<br>2'b01: select divider output from fraction divider<br>2'b10: select 24MHz from osc input |
| 7          | RO          | 0x0                | reserved                                                                                                                                                                                                   |
| 6:0        | RW          | 0x00               | uart1_div_con<br>Control UART1 divider frequency<br>clk_uart1=uart_clk_src/(uart1_div_con+1)                                                                                                               |

**CRU\_CLKSEL15\_CON**

Address: Operational Base + offset (0x0080)

Internal clock select and divide register 15

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 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:10      | RO          | 0x0                | reserved                                                                                                                                                                                                   |
| 9:8        | RW          | 0x2                | uart2_clk_sel<br>Control UART2 clock work frequency selection<br>2'b00: select divider output from pll divider<br>2'b01: select divider output from fraction divider<br>2'b10: select 24MHz from osc input |
| 7          | RO          | 0x0                | reserved                                                                                                                                                                                                   |
| 6:0        | RW          | 0x00               | uart2_div_con<br>Control UART2 divider frequency<br>clk_uart2=uart_clk_src/(uart2_div_con+1)                                                                                                               |

**CRU\_CLKSEL16\_CON**

Address: Operational Base + offset (0x0084)

Internal clock select and divide register 16

| <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          | 0x00               | nandc_div_con<br>clk_nandc_div_out=clk_nandc_src/(nandc_div_con+1)                                               |
| 9:8        | RW          | 0x2                | nandc_pll_sel<br>2'b00: select ARM PLL<br>2'b01: select DDR PLL<br>2'b10: select GENERAL PLL                     |
| 7          | RO          | 0x0                | reserved                                                                                                         |
| 6:2        | RW          | 0x00               | sfc_div_con<br>clk_sfc_div_out=clk_sfc_src/(sfc_div_con+1)                                                       |
| 1:0        | RW          | 0x2                | sfc_pll_sel<br>2'b00: select ARM PLL<br>2'b01: select DDR PLL<br>2'b10: select GENERAL PLL<br>2'b11: select X24M |

**CRU\_CLKSEL17\_CON**

Address: Operational Base + offset (0x0088)

Internal clock select and divide register 17

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x0bb8ea60         | uart0_frac_factor<br>Control UART0 fraction divider frequency<br>High 16-bit for numerator<br>Low 16-bit for denominator |

**CRU\_CLKSEL18\_CON**

Address: Operational Base + offset (0x008c)

Internal clock select and divide register 18

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x0bb8ea60         | uart1_frac_factor<br>Control UART1 fraction divider frequency<br>High 16-bit for numerator<br>Low 16-bit for denominator |

**CRU\_CLKSEL19\_CON**

Address: Operational Base + offset (0x0090)

Internal clock select and divide register 19

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x0bb8ea60         | uart2_frac_factor<br>Control UART2 fraction divider frequency<br>High 16-bit for numerator<br>Low 16-bit for denominator |

**CRU\_CLKSEL20\_CON**

Address: Operational Base + offset (0x0094)

Internal clock select and divide register 20

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------|
| 31:7       | RO          | 0x0                | reserved                                                                                    |
| 6:2        | RW          | 0x00               | hevc_div_con<br>clk_hevc_div_out=clk_hevc_src/(hevc_div_con+1)                              |
| 1:0        | RW          | 0x2                | hevc_pll_sel<br>2'b00: select ARM PLL<br>2'b01: select DDR PLL<br>2'b10: select GENERAL PLL |

**CRU\_CLKSEL21\_CON**

Address: Operational Base + offset (0x0098)

Internal clock select and divide register 21

| <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:14      | RO          | 0x0                | reserved                                                                                                                                |
| 13:9       | RW          | 0x00               | mac_div_con<br>clk_mac_div_out=clk_mac_src/(mac_div_con+1)                                                                              |
| 8:4        | RW          | 0x01               | macref_div_con<br>clk_macref=clk_macreref_muxout/(macref_div_con+1)                                                                     |
| 3          | RW          | 0x0                | rmii_extclk_sel<br>0: clk_macref_div_out<br>1: rmii_clkin                                                                               |
| 2          | RO          | 0x0                | reserved                                                                                                                                |
| 1:0        | RW          | 0x2                | mac_pll_sel<br>2'b00: select ARM PLL<br>2'b01: select DDR PLL<br>2'b10: select GENERAL PLL                                              |

**CRU\_CLKSEL25\_CON**

Address: Operational Base + offset (0x00a8)

Internal clock select and divide register 25

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 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:10      | RO          | 0x0                | reserved                                                                                                                                |
| 9:8        | RW          | 0x2                | spi_clk_pll_sel<br>SPI clock pll source selection<br>2'b00: select ARM PLL<br>2'b01: select DDR PLL<br>2'b10: select GENERAL PLL        |
| 7          | RO          | 0x0                | reserved                                                                                                                                |

| Bit | Attr | Reset Value | Description                                                                                                                     |
|-----|------|-------------|---------------------------------------------------------------------------------------------------------------------------------|
| 6:0 | RW   | 0x07        | spi0_div_con<br>Control SPI0 clock divider frequency<br>$\text{clk\_spi0} = \text{general\_pll\_clk}/(\text{spi0\_div\_con}+1)$ |

**CRU\_CLKSEL26\_CON**

Address: Operational Base + offset (0x00ac)

Internal clock select and divide register 26

| Bit   | Attr | Reset Value | Description                                                                                                                                                       |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 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:9  | RO   | 0x0         | reserved                                                                                                                                                          |
| 8     | RW   | 0x0         | ddr_clk_pll_sel<br>DDR clock pll source selection<br>1'b0: select DDR PLL<br>1'b1: select GENERAL PLL                                                             |
| 7:2   | RO   | 0x0         | reserved                                                                                                                                                          |
| 1:0   | RW   | 0x0         | ddr_div_sel<br>Control DDR divider frequency<br>2'b00: clk_ddr_src:clk_ddrphy = 1:1<br>2'b01: clk_ddr_src:clk_ddrphy = 2:1<br>2'b10: clk_ddr_src:clk_ddrphy = 4:1 |

**CRU\_CLKSEL28\_CON**

Address: Operational Base + offset (0x00b4)

Internal clock select and divide register 28

| Bit   | Attr | Reset Value | Description                                                                                                                                        |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 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:8  | RW   | 0x07        | lc当地_dclk_div_con<br>Control LCD display clock divider frequency<br>$\text{dclk\_lc当地1} = \text{lc当地_dclk_src}/(\text{lc当地_dclk_div_con}+1)$       |
| 7:2   | RO   | 0x0         | reserved                                                                                                                                           |
| 1:0   | RW   | 0x2         | lc当地_dclk_pll_sel<br>Control LCD display clock PLL source selection<br>2'b00: select ARM PLL<br>2'b01: select DDR PLL<br>2'b10: select GENERAL PLL |

**CRU\_CLKSEL30\_CON**

Address: Operational Base + offset (0x00bc)

Internal clock select and divide register 30

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                            |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 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:14      | RW          | 0x2                | vio_hclk_pll_sel<br>Control VIO AHB clock PLL source selection<br>2'b00: select ARM PLL<br>2'b01: select DDR PLL<br>2'b10: select GENERAL PLL |
| 13         | RO          | 0x0                | reserved                                                                                                                                      |
| 12:8       | RW          | 0x03               | vio_hclk_div_con<br>Control VIO AHB clock divider frequency<br>$hclk_vio = vio\_hclk\_src / (vio\_hclk\_div\_con + 1)$                        |
| 7:5        | RO          | 0x0                | reserved                                                                                                                                      |
| 4:0        | RW          | 0x00               | testout_div_con<br>testout clock divider frequency<br>$clk_{testout} = testout\_clk\_src / (testout\_div\_con + 1)$                           |

**CRU\_CLKSEL31\_CON**

Address: Operational Base + offset (0x00c0)

Internal clock select and divide register 31

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 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:14      | RW          | 0x2                | lcdc_aclk_pll_sel<br>Control LCDC AXI clock PLL source selection<br>2'b00: select ARM PLL<br>2'b01: select DDR PLL<br>2'b10: select GENERAL PLL |
| 13         | RO          | 0x0                | reserved                                                                                                                                        |
| 12:8       | RW          | 0x00               | lcdc_aclk_div_con<br>Control LCDC AXI clock divider frequency<br>$aclk_{lcdc1} = lcdc1\_aclk\_src / (lcdc1\_aclk\_div\_con + 1)$                |
| 7:1        | RO          | 0x0                | reserved                                                                                                                                        |
| 0          | RW          | 0x0                | hdmi_clk_sel<br>0: hdmi vclk_pllref from vop dclk;<br>1: hdmi vclk_pllref from cru dclk ;                                                       |

**CRU\_CLKSEL32\_CON**

Address: Operational Base + offset (0x00c4)

Internal clock select and divide register 32

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 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 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:14      | RW          | 0x2                | vdpu_aclk_pll_sel<br>Control VDPU AXI clock PLL source selection<br>2'b00: select ARM PLL<br>2'b01: select DDR PLL<br>2'b10: select GENERAL PLL |
| 13         | RO          | 0x0                | reserved                                                                                                                                        |
| 12:8       | RW          | 0x00               | vdpu_aclk_div_con<br>Control VDPU AXI clock divider frequency<br>$aclk_{vdpu} = aclk_{src} / (vdpu\_aclk\_div\_con + 1)$                        |
| 7:0        | RO          | 0x0                | reserved                                                                                                                                        |

**CRU\_CLKSEL34\_CON**

Address: Operational Base + offset (0x00cc)

Internal clock select and divide register 34

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                            |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 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:10      | RO          | 0x0                | reserved                                                                                                                                      |
| 9:8        | RW          | 0x2                | gpu_aclk_pll_sel<br>Control GPU AXI clock PLL source selection<br>2'b00: select ARM PLL<br>2'b01: select DDR PLL<br>2'b10: select GENERAL PLL |
| 7:5        | RO          | 0x0                | reserved                                                                                                                                      |
| 4:0        | RW          | 0x00               | gpu_aclk_div_con<br>Control GPU AXI clock divider frequency<br>$aclk_{gpu} = aclk_{src} / (gpu\_aclk\_div\_con + 1)$                          |

**CRU\_CLKGATE0\_CON**

Address: Operational Base + offset (0x00d0)

Internal clock gating control register 0

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 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                | testclk_gate_en<br>Test output clock disable<br>When HIGH, disable clock                                                                |
| 14         | RW          | 0x0                | clk_i2s1_en<br>When HIGH, disable clock                                                                                                 |
| 13         | RW          | 0x0                | clk_i2s1_out_en<br>When HIGH, disable clock                                                                                             |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------|
| 12         | RW          | 0x0                | clk_crypto_gate_en<br>crypto clock disable.<br>When HIGH, disable clock                                    |
| 11         | RW          | 0x0                | hclk_disp_gate_en<br>display AHB clock disable.<br>When HIGH, disable clock                                |
| 10         | RW          | 0x0                | clk_i2s_frac_src_gate_en<br>I2S fraction divider source clock disable.<br>When HIGH, disable clock         |
| 9          | RW          | 0x0                | clk_i2s_src_gate_en<br>I2S source clock disable.<br>When HIGH, disable clock                               |
| 8          | RW          | 0x0                | clk_ddrphy_src_gpll_gate_en<br>DDR PHY clock(clk_ddrphy) gpll source disable.<br>When HIGH, disable clock  |
| 7          | RW          | 0x0                | aclk_core_gate_en<br>ARM core axi clock(aclk_core) disable.<br>When HIGH, disable clock                    |
| 6          | RW          | 0x0                | core_gpll_clk_gate_en<br>CORE clock GPLL path clock disable.<br>When HIGH, disable clock                   |
| 5          | RW          | 0x0                | pclk_cpu_gate_en<br>CPU system APB clock(pclk_cpu_pre) disable.<br>When HIGH, disable clock                |
| 4          | RW          | 0x0                | hclk_cpu_gate_en<br>CPU system AHB clock(hclk_cpu_pre) disable.<br>When HIGH, disable clock                |
| 3          | RW          | 0x0                | aclk_cpu_gate_en<br>CPU system AXI clock(aclk_cpu_pre) disable.<br>When HIGH, disable clock                |
| 2          | RW          | 0x0                | clk_ddrphy_src_gate_en<br>DDR PHY clock(clk_ddrphy) disable.<br>When HIGH, disable clock                   |
| 1          | RW          | 0x0                | cpu_gpll_clk_gate_en<br>CPU clock GPLL path clock disable.<br>When HIGH, disable clock                     |
| 0          | RW          | 0x0                | clk_core_periph_gate_en<br>ARM core peripheral clock(clk_core_periph) disable.<br>When HIGH, disable clock |

**CRU\_CLKGATE1\_CON**

Address: Operational Base + offset (0x00d4)

Internal clock gating control register 1

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 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:14      | RO          | 0x0                | reserved                                                                                                                                |
| 13         | RW          | 0x0                | clk_uart2_frac_src_gate_en<br>UART2 fraction divider source clock disable.<br>When HIGH, disable clock                                  |
| 12         | RW          | 0x0                | clk_uart2_src_gate_en<br>UART2 source clock disable.<br>When HIGH, disable clock                                                        |
| 11         | RW          | 0x0                | clk_uart1_frac_src_gate_en<br>UART1 fraction divider source clock disable.<br>When HIGH, disable clock                                  |
| 10         | RW          | 0x0                | clk_uart1_src_gate_en<br>UART1 source clock disable.<br>When HIGH, disable clock                                                        |
| 9          | RW          | 0x0                | clk_uart0_frac_src_gate_en<br>UART0 fraction divider source clock disable.<br>When HIGH, disable clock                                  |
| 8          | RW          | 0x0                | clk_uart0_src_gate_en<br>UART0 source clock disable.<br>When HIGH, disable clock                                                        |
| 7          | RO          | 0x0                | reserved                                                                                                                                |
| 6          | RW          | 0x0                | clk_otgphy1_gate_en<br>OTGPHY1 clock(clk_otgphy1) disable.<br>When HIGH, disable clock                                                  |
| 5          | RW          | 0x0                | clk_otgphy0_gate_en<br>OTGPHY0 clock(clk_otgphy0) disable.<br>When HIGH, disable clock                                                  |
| 4          | RW          | 0x0                | ack_lcdc_src_gate_en<br>ack_lcdc_src clock disable.<br>When HIGH, disable clock                                                         |
| 3          | RW          | 0x0                | clk_jtag_gate_en<br>JTAG clock disable.<br>When HIGH, disable clock                                                                     |
| 2          | RO          | 0x0                | reserved                                                                                                                                |
| 1          | RW          | 0x0                | clk_timer1_gate_en<br>Timer1 clock(clk_timer1) disable.<br>When HIGH, disable clock                                                     |
| 0          | RW          | 0x0                | clk_timer0_gate_en<br>Timer0 clock(clk_timer0) disable.<br>When HIGH, disable clock                                                     |

**CRU\_CLKGATE2\_CON**

Address: Operational Base + offset (0x00d8)

## Internal clock gating control register 2

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 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         | RO          | 0x0                | reserved                                                                                                                                |
| 14         | RW          | 0x0                | clk_emmc_src_gate_en<br>EMMC source clock disable.<br>When HIGH, disable clock                                                          |
| 13         | RW          | 0x0                | clk_sdio_src_gate_en<br>SDIO source clock disable.<br>When HIGH, disable clock                                                          |
| 12         | RW          | 0x0                | clk_spdif_frac_src_en<br>When HIGH, disable clock                                                                                       |
| 11         | RW          | 0x0                | clk_mmc0_src_gate_en<br>SDMMC0 source clock disable.<br>When HIGH, disable clock                                                        |
| 10         | RW          | 0x0                | clk_spdif_src_en<br>When HIGH, disable clock                                                                                            |
| 9          | RW          | 0x0                | clk_spi0_src_gate_en<br>SPI0 source clock disable.<br>When HIGH, disable clock                                                          |
| 8:7        | RO          | 0x0                | reserved                                                                                                                                |
| 6          | RW          | 0x0                | clk_mac_lbtest_en<br>When HIGH, disable clock                                                                                           |
| 5          | RW          | 0x0                | clk_timer3_en<br>When HIGH, disable clock                                                                                               |
| 4          | RW          | 0x0                | clk_timer2_en<br>When HIGH, disable clock                                                                                               |
| 3          | RW          | 0x0                | pclk_periph_gate_en<br>PERIPH system APB clock(pclk_periph) disable.<br>When HIGH, disable clock                                        |
| 2          | RW          | 0x0                | hclk_periph_gate_en<br>PERIPH system AHB clock(hclk_periph) disable.<br>When HIGH, disable clock                                        |
| 1          | RW          | 0x0                | aclk_periph_gate_en<br>PERIPH system AXI clock(aclk_periph) disable.<br>When HIGH, disable clock                                        |
| 0          | RW          | 0x0                | clk_periph_src_gate_en<br>PERIPH system source clock disable.<br>When HIGH, disable clock                                               |

**CRU\_CLKGATE3\_CON**

Address: Operational Base + offset (0x00dc)

Internal clock gating control register 3

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 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         | RO          | 0x0                | reserved                                                                                                                                |
| 14         | RW          | 0x0                | hclk_sfc_gate_en<br>SFC AHB bus source axi clock disable.<br>When HIGH, disable clock                                                   |
| 13         | RW          | 0x0                | aclk_gpu_src_gate_en<br>GPU AXI source clock disable.<br>When HIGH, disable clock                                                       |
| 12         | RW          | 0x0                | hclk_vdpu_gate_en<br>VDPU AHB source clock disable.<br>When HIGH, disable clock                                                         |
| 11         | RW          | 0x0                | aclk_vdpu_src_gate_en<br>VDPU AXI source clock disable.<br>When HIGH, disable clock                                                     |
| 10:3       | RO          | 0x0                | reserved                                                                                                                                |
| 2          | RW          | 0x0                | dclk_lcdc_src_gate_en<br>LCDC DCLK souce clock disable.<br>When HIGH, disable clock                                                     |
| 1:0        | RO          | 0x0                | reserved                                                                                                                                |

**CRU\_CLKGATE4\_CON**

Address: Operational Base + offset (0x00e0)

Internal clock gating control register 4

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 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:13      | RO          | 0x0                | reserved                                                                                                                                |
| 12         | RW          | 0x0                | aclk_intmem_gate_en<br>Internal memory AXI clock(aclk_intmem) disable.<br>When HIGH, disable clock                                      |
| 11         | RO          | 0x0                | reserved                                                                                                                                |
| 10         | RW          | 0x0                | aclk_strc_sys_gate_en<br>CPU Structure system AXI clock disable.<br>When HIGH, disable clock                                            |
| 9:4        | RO          | 0x0                | reserved                                                                                                                                |
| 3          | RW          | 0x0                | aclk_peri_axi_matrix_gate_en<br>PERIPH matrix CPU AXI clock(aclk_peri_axi_matrix) disable.<br>When HIGH, disable clock                  |
| 2          | RW          | 0x0                | aclk_cpu_peri_gate_en<br>PERIPH CPU AXI clock(aclk_cpu_peri) disable.<br>When HIGH, disable clock                                       |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------|
| 1          | RW          | 0x0                | pclk_peri_axi_matrix_gate_en<br>PERIPH matrix CPU APB clock(pclk_peri_axi_matrix) disable.<br>When HIGH, disable clock |
| 0          | RW          | 0x0                | hclk_peri_axi_matrix_gate_en<br>PERIPH matrix CPU AHB clock(hclk_peri_axi_matrix) disable.<br>When HIGH, disable clock |

**CRU\_CLKGATE5\_CON**

Address: Operational Base + offset (0x00e4)

Internal clock gating control register 5

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 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         | RO          | 0x0                | reserved                                                                                                                                |
| 14         | RW          | 0x0                | pclk_acodec_gate_en<br>audio codec APB clock disable.<br>When HIGH, disable clock                                                       |
| 13         | RW          | 0x0                | hclk_otg0_gate_en<br>USB OTG PHY0 AHB clock disable.<br>When HIGH, disable clock                                                        |
| 12         | RO          | 0x0                | reserved                                                                                                                                |
| 11         | RW          | 0x0                | hclk_sdio_gate_en<br>SDIO AHB clock disable.<br>When HIGH, disable clock                                                                |
| 10         | RW          | 0x0                | hclk_sdmmc0_gate_en<br>SDMMC0 AHB clock disable<br>When HIGH, disable clock                                                             |
| 9          | RW          | 0x0                | hclk_nandc_gate_en<br>NANDC AHB clock disable<br>When HIGH, disable clock                                                               |
| 8          | RO          | 0x0                | reserved                                                                                                                                |
| 7          | RW          | 0x0                | pclk_ddrupctl_gate_en<br>DDR uPCTL APB clock disable.<br>When HIGH, disable clock                                                       |
| 6          | RW          | 0x0                | hclk_rom_gate_en<br>ROM AHB clock disable.<br>When HIGH, disable clock                                                                  |
| 5          | RO          | 0x0                | reserved                                                                                                                                |
| 4          | RW          | 0x0                | pclk_grf_gate_en<br>GRF APB clock disable.<br>When HIGH, disable clock                                                                  |
| 3          | RO          | 0x0                | reserved                                                                                                                                |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------|
| 2          | RW          | 0x0                | pclk_efuse_gate_en<br>EFUSE APB clock disable.<br>When HIGH, disable clock |
| 1          | RW          | 0x0                | ackl_dmac2_gate_en<br>DMAC2 AXI clock disable.<br>When HIGH, disable clock |
| 0          | RO          | 0x0                | reserved                                                                   |

**CRU\_CLKGATE6\_CON**

Address: Operational Base + offset (0x00e8)

Internal clock gating control register 6

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 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:14      | RO          | 0x0                | reserved                                                                                                                                |
| 13         | RW          | 0x0                | ackl_vio_gate_en<br>VIO0 AXI clock disable.<br>When HIGH, disable clock                                                                 |
| 12         | RW          | 0x0                | hclk_vio_bus_gate_en<br>VIO AHB bus clock disable.<br>When HIGH, disable clock                                                          |
| 11:0       | RO          | 0x0                | reserved                                                                                                                                |

**CRU\_CLKGATE7\_CON**

Address: Operational Base + offset (0x00ec)

Internal clock gating control register 7

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 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                | pclk_wdt_gate_en<br>WDT APB clock disable.<br>When HIGH, disable clock                                                                  |
| 14:13      | RO          | 0x0                | reserved                                                                                                                                |
| 12         | RW          | 0x0                | pclk_spi0_gate_en<br>SPI0 APB clock disable.<br>When HIGH, disable clock                                                                |
| 11         | RO          | 0x0                | reserved                                                                                                                                |
| 10         | RW          | 0x0                | pclk_pwm01_gate_en<br>PWM0 and PWM1 APB clock disable.<br>When HIGH, disable clock                                                      |
| 9:8        | RO          | 0x0                | reserved                                                                                                                                |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------|
| 7          | RW          | 0x0                | pclk_timer0_gate_en<br>TIMER0 APB clock disable.<br>When HIGH, disable clock     |
| 6:4        | RO          | 0x0                | reserved                                                                         |
| 3          | RW          | 0x0                | hclk_otg1_gate_en<br>USB OTG PHY1 AHB clock disable.<br>When HIGH, disable clock |
| 2          | RW          | 0x0                | hclk_i2s_gate_en<br>I2S AHB clock disable.<br>When HIGH, disable clock           |
| 1          | RO          | 0x0                | reserved                                                                         |
| 0          | RW          | 0x0                | hclk_emmc_gate_en<br>EMMC AHB clock disable.<br>When HIGH, disable clock         |

**CRU\_CLKGATE8\_CON**

Address: Operational Base + offset (0x00f0)

Internal clock gating control register 8

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 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:12      | RO          | 0x0                | reserved                                                                                                                                |
| 11         | RW          | 0x0                | pclk_gpio2_gate_en<br>GPIO2 APB clock disable.<br>When HIGH, disable clock                                                              |
| 10         | RW          | 0x0                | pclk_gpio1_gate_en<br>GPIO1 APB clock disable.<br>When HIGH, disable clock                                                              |
| 9          | RW          | 0x0                | pclk_gpio0_gate_en<br>GPIO0 APB clock disable.<br>When HIGH, disable clock                                                              |
| 8:7        | RO          | 0x0                | reserved                                                                                                                                |
| 6          | RW          | 0x0                | pclk_i2c2_gate_en<br>I2C2 APB clock disable.<br>When HIGH, disable clock                                                                |
| 5          | RW          | 0x0                | pclk_i2c1_gate_en<br>I2C1 APB clock disable.<br>When HIGH, disable clock                                                                |
| 4          | RW          | 0x0                | pclk_i2c0_gate_en<br>I2C0 APB clock disable.<br>When HIGH, disable clock                                                                |
| 3          | RO          | 0x0                | reserved                                                                                                                                |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------|
| 2          | RW          | 0x0                | pclk_uart2_gate_en<br>UART2 APB clock disable.<br>When HIGH, disable clock |
| 1          | RW          | 0x0                | pclk_uart1_gate_en<br>UART1 APB clock disable.<br>When HIGH, disable clock |
| 0          | RW          | 0x0                | pclk_uart0_gate_en<br>UART0 APB clock disable.<br>When HIGH, disable clock |

**CRU\_CLKGATE9\_CON**

Address: Operational Base + offset (0x00f4)

Internal clock gating control register 9

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 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                | ackl_peri_niu_clock_en<br>periph NIU AXI clock disable.<br>When HIGH, disable clock                                                     |
| 14         | RW          | 0x0                | hclk_peri_arbi_clock_en<br>periph arbitor AHB clock disable.<br>When HIGH, disable clock                                                |
| 13         | RW          | 0x0                | hclk_usb_peri_clock_en<br>USB peri AHB clock disable.<br>When HIGH, disable clock                                                       |
| 12:7       | RO          | 0x0                | reserved                                                                                                                                |
| 6          | RW          | 0x0                | ackl_lcdc_clock_en<br>LCDC1 AXI clock disable.<br>When HIGH, disable clock                                                              |
| 5          | RW          | 0x0                | hclk_lcdc_clock_en<br>LCDC1 AHB clock disable.<br>When HIGH, disable clock                                                              |
| 4:0        | RO          | 0x0                | reserved                                                                                                                                |

**CRU\_CLKGATE10\_CON**

Address: Operational Base + offset (0x00f8)

Internal clock gating control register 10

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------|
| 31:9       | RO          | 0x0                | reserved                                                                                                                    |
| 8          | RW          | 0x0                | cpu_dpll_clk_en<br>To generate ackl_cpu_src, we use 3 clock source: apll, dpll, gpll.<br>This gating is gating dpll source. |
| 7          | RO          | 0x0                | reserved                                                                                                                    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                            |
|------------|-------------|--------------------|-----------------------------------------------|
| 6          | RW          | 0x0                | clk_hevc_core_en<br>When HIGH, disable clock  |
| 5          | RW          | 0x0                | clk_sfc_src_en<br>When HIGH, disable clock    |
| 4          | RW          | 0x0                | clk_nandc_src_en<br>When HIGH, disable clock  |
| 3          | RO          | 0x0                | reserved                                      |
| 2          | RW          | 0x0                | clk_pvtm_video_en<br>When HIGH, disable clock |
| 1          | RW          | 0x0                | clk_pvtm_gpu_en<br>When HIGH, disable clock   |
| 0          | RW          | 0x0                | clk_pvtm_core_en<br>When HIGH, disable clock  |

**CRU\_GLB\_SRST\_FST\_VALUE**

Address: Operational Base + offset (0x0100)

The first global software reset config value

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0                | reserved                                                                                                                              |
| 15:0       | RW          | 0x0000             | glb_srst_fst_value<br>The first global software reset config value<br>If config 0xfdb9, it will generate first global software reset. |

**CRU\_GLB\_SRST SND\_VALUE**

Address: Operational Base + offset (0x0104)

The second global software reset config value

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0                | reserved                                                                                                                                 |
| 15:0       | RW          | 0x0000             | glb_srst_snd_value<br>The second global software reset config value<br>If config 0xecfa8, it will generate second global software reset. |

**CRU\_SOFTRST0\_CON**

Address: Operational Base + offset (0x0110)

Internal software reset control register 0

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 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                | pd_core_niu_arstn_req<br>Core noc aclk software reset request.<br>When HIGH, reset relative logic                                       |
| 14         | RW          | 0x0                | strc_sys_asrstn_req<br>Structre system AXI software reset request.<br>When HIGH, reset relative logic                                   |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------|
| 13         | RW          | 0x0                | topdbg_srstn_req<br>When HIGH, reset relative logic                                               |
| 12         | RW          | 0x0                | I2c_srstn_req<br>L2C software reset request.<br>When HIGH, reset relative logic                   |
| 11:10      | RO          | 0x0                | reserved                                                                                          |
| 9          | R/W SC      | 0x0                | core1_por_srstn_req<br>core1 por reset software reset request.<br>When HIGH, reset relative logic |
| 8          | R/W SC      | 0x0                | core0_por_srstn_req<br>core0 por reset software reset request.<br>When HIGH, reset relative logic |
| 7:6        | RO          | 0x0                | reserved                                                                                          |
| 5          | RW          | 0x0                | core1_dbg_srstn_req<br>core1 CPU debug software reset request.<br>When HIGH, reset relative logic |
| 4          | RW          | 0x0                | core0_dbg_srstn_req<br>core0 CPU debug software reset request.<br>When HIGH, reset relative logic |
| 3:2        | RO          | 0x0                | reserved                                                                                          |
| 1          | R/W SC      | 0x0                | core1_srstn_req<br>core1 CPU software reset request.<br>When HIGH, reset relative logic           |
| 0          | R/W SC      | 0x0                | core0_srstn_req<br>core0 CPU software reset request.<br>When HIGH, reset relative logic           |

**CRU\_SOFTRST1\_CON**

Address: Operational Base + offset (0x0114)

Internal software reset control register 1

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 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                | acodec_psrstn_req<br>audio codec software reset request.<br>When HIGH, reset relative logic                                             |
| 14         | RW          | 0x0                | efuse_psrstn_req<br>EFUSE APB software reset request.<br>When HIGH, reset relative logic                                                |
| 13         | RW          | 0x0                | core_dll_srstn_req<br>CORE DLL software reset request.<br>When HIGH, reset relative logic                                               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                             |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------|
| 12         | RW          | 0x0                | timer1_srstn_req<br>Timer1 software reset request.<br>When HIGH, reset relative logic          |
| 11         | RW          | 0x0                | timer0_srstn_req<br>Timer0 software reset request.<br>When HIGH, reset relative logic          |
| 10         | RW          | 0x0                | gpu_dll_srstn_req<br>GPU DLL software reset request.<br>When HIGH, reset relative logic        |
| 9          | RW          | 0x0                | video_pll_srstn_req<br>Video pll software reset request.<br>When HIGH, reset relative logic    |
| 8          | RW          | 0x0                | i2s_srstn_req<br>I2S software reset request.<br>When HIGH, reset relative logic                |
| 7          | RW          | 0x0                | peri_niu_srstn_req<br>periph_niu software reset request.<br>When HIGH, reset relative logic    |
| 6          | RW          | 0x0                | rom_srstn_req<br>ROM software reset request.<br>When HIGH, reset relative logic                |
| 5          | RW          | 0x0                | intmem_srstn_req<br>Internal memory software reset request.<br>When HIGH, reset relative logic |
| 4          | RW          | 0x0                | timer3_srstn_req<br>Timer3 clock software reset request.<br>When HIGH, reset relative logic    |
| 3          | RW          | 0x0                | ahb2apb_hsrstn_req<br>AHB2APB software reset request.<br>When HIGH, reset relative logic       |
| 2          | RO          | 0x0                | reserved                                                                                       |
| 1          | RW          | 0x0                | cpusys_hsrstn_req<br>CPU AHB software reset request.<br>When HIGH, reset relative logic        |
| 0          | RW          | 0x0                | timer2_srstn_req<br>Timer2 clock software reset request.<br>When HIGH, reset relative logic    |

**CRU\_SOFTRST2\_CON**

Address: Operational Base + offset (0x0118)

Internal software reset control register 2

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 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 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------|
| 15         | RW          | 0x0                | sfc_srstn_req<br>SFC clock software reset request.<br>When HIGH, reset relative logic |
| 14         | RO          | 0x0                | reserved                                                                              |
| 13         | RW          | 0x0                | i2c2_srstn_req<br>I2C2 software reset request.<br>When HIGH, reset relative logic     |
| 12         | RW          | 0x0                | i2c1_srstn_req<br>I2C1 software reset request.<br>When HIGH, reset relative logic     |
| 11         | RW          | 0x0                | i2c0_srstn_req<br>I2C0 software reset request.<br>When HIGH, reset relative logic     |
| 10         | RO          | 0x0                | reserved                                                                              |
| 9          | RW          | 0x0                | uart2_srstn_req<br>UART2 software reset request.<br>When HIGH, reset relative logic   |
| 8          | RW          | 0x0                | uart1_srstn_req<br>UART1 software reset request.<br>When HIGH, reset relative logic   |
| 7          | RW          | 0x0                | uart0_srstn_req<br>UART0 software reset request.<br>When HIGH, reset relative logic   |
| 6:3        | RO          | 0x0                | reserved                                                                              |
| 2          | RW          | 0x0                | gpio2_srstn_req<br>GPIO2 software reset request.<br>When HIGH, reset relative logic   |
| 1          | RW          | 0x0                | gpio1_srstn_req<br>GPIO1 software reset request.<br>When HIGH, reset relative logic   |
| 0          | RW          | 0x0                | gpio0_srstn_req<br>GPIO0 software reset request.<br>When HIGH, reset relative logic   |

**CRU\_SOFRST3\_CON**

Address: Operational Base + offset (0x011c)

Internal software reset control register 3

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 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                | usb_peri_srstn_req<br>USB PERIPH software reset request.<br>When HIGH, reset relative logic                                             |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                            |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------|
| 14         | RW          | 0x0                | emem_peri_srstn_req<br>EMEM PERIPH software reset request.<br>When HIGH, reset relative logic |
| 13         | RW          | 0x0                | cpu_peri_srstn_req<br>CPU PERIPH software reset request.<br>When HIGH, reset relative logic   |
| 12         | RO          | 0x0                | reserved                                                                                      |
| 11         | RW          | 0x0                | periphsys_psrstn_req<br>PERIPH APP software reset request.<br>When HIGH, reset relative logic |
| 10         | RW          | 0x0                | periphsys_hsrstn_req<br>PERIPH AHB software reset request.<br>When HIGH, reset relative logic |
| 9          | RW          | 0x0                | periphsys_asrstn_req<br>PERIPH AXI software reset request.<br>When HIGH, reset relative logic |
| 8          | RO          | 0x0                | reserved                                                                                      |
| 7          | RW          | 0x0                | grf_srstn_req<br>GRF software reset request.<br>When HIGH, reset relative logic               |
| 6:5        | RO          | 0x0                | reserved                                                                                      |
| 4          | RW          | 0x0                | dap_sys_srstn_req<br>DAP system software reset request.<br>When HIGH, reset relative logic    |
| 3          | RW          | 0x0                | dap_srstn_req<br>DAP software reset request.<br>When HIGH, reset relative logic               |
| 2:1        | RO          | 0x0                | reserved                                                                                      |
| 0          | RW          | 0x0                | pwm0_srstn_req<br>PWM0 software reset request.<br>When HIGH, reset relative logic             |

**CRU\_SOFTRST4\_CON**

Address: Operational Base + offset (0x0120)

Internal software reset control register 4

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 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                | ddrmsch_srstn_req<br>DDR memory scheduler software reset request.<br>When HIGH, reset relative logic                                    |
| 14:11      | RO          | 0x0                | reserved                                                                                                                                |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 10         | RW          | 0x0                | otgc1_srstn_req<br>OTG controller1 software reset request.<br>When HIGH, reset relative logic<br>Host Controller utmi_clk domain reset  |
| 9          | RO          | 0x0                | reserved                                                                                                                                |
| 8          | RW          | 0x0                | usb0tg1_srstn_req<br>USBOTG1 software reset request.<br>When HIGH, reset relative logic<br>Host Controller hclk domain reset.           |
| 7          | RW          | 0x0                | otgc0_srstn_req<br>OTG controller0 software reset request.<br>When HIGH, reset relative logic.<br>OTG Controller utmi_clk domain reset. |
| 6          | RO          | 0x0                | reserved                                                                                                                                |
| 5          | RW          | 0x0                | usb0tg0_srstn_req<br>USBOTG0 software reset request.<br>When HIGH, reset relative logic<br>OTG Controller hclk domain reset.            |
| 4          | RW          | 0x0                | nandc_srstn_req<br>NANDC software reset request.<br>When HIGH, reset relative logic                                                     |
| 3          | RO          | 0x0                | reserved                                                                                                                                |
| 2          | RW          | 0x0                | mac_srstn_req<br>Mac clock software reset request.<br>When HIGH, reset relative logic                                                   |
| 1          | RO          | 0x0                | reserved                                                                                                                                |
| 0          | RW          | 0x0                | dma2_srstn_req<br>DMA2 software reset request.<br>When HIGH, reset relative logic                                                       |

**CRU\_SOFTRST5\_CON**

Address: Operational Base + offset (0x0124)

Internal software reset control register 5

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 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:12      | RO          | 0x0                | reserved                                                                                                                                |
| 11         | RW          | 0x0                | ddrctrl_psrstn_req<br>DDR controller APB software reset request.<br>When HIGH, reset relative logic                                     |
| 10         | RW          | 0x0                | ddrctrl_srstn_req<br>DDR controller software reset request.<br>When HIGH, reset relative logic                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------|
| 9          | RW          | 0x0                | ddrphy_psrstn_req<br>DDR PHY APB software reset request.<br>When HIGH, reset relative logic |
| 8          | RW          | 0x0                | ddrphy_srstn_req<br>DDR PHY software reset request.<br>When HIGH, reset relative logic      |
| 7          | RO          | 0x0                | reserved                                                                                    |
| 6          | RW          | 0x0                | wdt_srstn_req<br>WDT software reset request.<br>When HIGH, reset relative logic             |
| 5          | RO          | 0x0                | reserved                                                                                    |
| 4          | RW          | 0x0                | spi0_srstn_req<br>SPI0 software reset request.<br>When HIGH, reset relative logic           |
| 3          | RW          | 0x0                | emmc_srstn_req<br>EMMC software reset request.<br>When HIGH, reset relative logic           |
| 2          | RW          | 0x0                | sdio_srstn_req<br>SDIO software reset request.<br>When HIGH, reset relative logic           |
| 1          | RW          | 0x0                | mmc0_srstn_req<br>SDMMC0 software reset request.<br>When HIGH, reset relative logic         |
| 0          | RO          | 0x0                | reserved                                                                                    |

**CRU\_SOFTRST6\_CON**

Address: Operational Base + offset (0x0128)

Internal software reset control register 6

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 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:10      | RO          | 0x0                | reserved                                                                                                                                                           |
| 9          | RW          | 0x0                | usbpor_srst_req<br>USBPHY POR software reset request.<br>When HIGH, reset relative logic.<br>USB phy analog domain reset, including both OTG and HOST phy .        |
| 8          | RW          | 0x0                | utmi1_srst_req<br>UTMI1 software reset request.<br>When HIGH, reset relative logic<br>HOST phy digital domain reset. It should last at least 10 utmi_clk_1 cycles. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7          | RW          | 0x0                | utmi0_srstn_req<br>UTMI0 software reset request.<br>When HIGH, reset relative logic<br>OTG phy digital domain reset. It should last at least 10 utmi_clk_0 cycles. |
| 6:4        | RO          | 0x0                | reserved                                                                                                                                                           |
| 3          | RW          | 0x0                | vio_bus_hsrstn_req<br>VIO bus AHB software reset request.<br>When HIGH, reset relative logic                                                                       |
| 2:1        | RO          | 0x0                | reserved                                                                                                                                                           |
| 0          | RW          | 0x0                | hdmi_psrstn_req<br>HDMI PCLK software reset request.<br>When HIGH, reset relative logic                                                                            |

**CRU\_SOFTRST7\_CON**

Address: Operational Base + offset (0x012c)

Internal software reset control register 7

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 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:11      | RO          | 0x0                | reserved                                                                                                                                |
| 10         | RW          | 0x0                | gpu_niu_asrstn_req<br>GPU NIU AXI software reset request.<br>When HIGH, reset relative logic                                            |
| 9          | RO          | 0x0                | reserved                                                                                                                                |
| 8          | RW          | 0x0                | gpu_srstn_req<br>GPU core software reset request.<br>When HIGH, reset relative logic                                                    |
| 7          | RW          | 0x0                | lc当地d_srstn_req<br>LCDC1 DCLK software reset request.<br>When HIGH, reset relative logic                                                |
| 6          | RW          | 0x0                | lc当地c_hsrstn_req<br>LCDC1 AHB software reset request.<br>When HIGH, reset relative logic                                                |
| 5          | RW          | 0x0                | lc当地c_asrstn_req<br>LCDC1 AXI software reset request.<br>When HIGH, reset relative logic                                                |
| 4          | RW          | 0x0                | vcodec_niu_asrstn_req<br>VCODEC NIU AXI software reset request.<br>When HIGH, reset relative logic                                      |
| 3          | RW          | 0x0                | hevc_srstn_req<br>Hevc clock software reset request.<br>When HIGH, reset relative logi                                                  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------|
| 2          | RW          | 0x0                | vio1_asrstn_req<br>VIO second AXI software reset request.<br>When HIGH, reset relative logic |
| 1          | RW          | 0x0                | vcodec_hsrstn_req<br>VCODEC AHB software reset request.<br>When HIGH, reset relative logic   |
| 0          | RW          | 0x0                | vcodec_asrstn_req<br>VCODEC AXI software reset request.<br>When HIGH, reset relative logic   |

**CRU\_SOFRST8\_CON**

Address: Operational Base + offset (0x0130)

Internal software reset control register 8

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 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:4       | RO          | 0x0                | reserved                                                                                                                                |
| 3          | RW          | 0x0                | dbg_psrstn_req<br>DEBUG APB software reset request.<br>When HIGH, reset relative logic                                                  |
| 2:0        | RO          | 0x0                | reserved                                                                                                                                |

**CRU\_MISC\_CON**

Address: Operational Base + offset (0x0134)

SCU control register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 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                | usb480m_24m_sel<br>0: usbphy480m;<br>1: xin24m                                                                                                                                               |
| 14:11      | RO          | 0x0                | reserved                                                                                                                                                                                     |
| 10:8       | RW          | 0x0                | testclk_sel<br>Output clock selection for test<br>3'b001: clk_i2s<br>3'b010: clk_core<br>3'b011: clk_ddrphy<br>3'b100: sclk_lcdc<br>3'b101: clk_gpu<br>3'b110: aclk_peri<br>3'b111: aclk_cpu |
| 7:1        | RO          | 0x0                | reserved                                                                                                                                                                                     |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                             |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------|
| 0          | RW          | 0x0                | core0_porst_wdt_sel<br>Select reset watchdog when A7 core 0 power on reset<br>1'b0: not reset watchdog<br>1'b1: reset watchdog |

**CRU\_GLB\_CNT\_TH**

Address: Operational Base + offset (0x0140)

global reset wait counter threshold

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x3a98             | pll_lock_period<br>PLL lock period                                                   |
| 15         | RW          | 0x0                | cru_wdt_con<br>1'b1: watch dog first soft reset<br>1'b0: watch dog second soft reset |
| 14:10      | RO          | 0x0                | reserved                                                                             |
| 9:0        | RW          | 0x064              | glb_RST_CNT_TH<br>Global soft reset counter threshold                                |

**CRU\_SDMMC\_CON0**

Address: Operational Base + offset (0x0144)

SDMMC clock generation control register 0

| <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:12      | RO          | 0x0                | reserved                                                                                                                                |
| 11         | RW          | 0x0                | drv_sel<br>drv select                                                                                                                   |
| 10:3       | RW          | 0x00               | drv_delaynum<br>drv delaynum                                                                                                            |
| 2:1        | RW          | 0x2                | drv_degree<br>drive degree                                                                                                              |
| 0          | RW          | 0x0                | init_state<br>initial state                                                                                                             |

**CRU\_SDMMC\_CON1**

Address: Operational Base + offset (0x0148)

SDMMC clock generation control register 1

| <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:11      | RO          | 0x0                | reserved                                                                                                                                |
| 10         | RW          | 0x0                | sample_sel<br>sample select                                                                                                             |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                 |
|------------|-------------|--------------------|------------------------------------|
| 9:2        | RW          | 0x00               | sample_delaynum<br>sample delaynum |
| 1:0        | RW          | 0x0                | sample_degree<br>sample degree     |

**CRU\_SDIO\_CON0**

Address: Operational Base + offset (0x014c)

SDIO clock generation control register 0

| <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:12      | RO          | 0x0                | reserved                                                                                                                                |
| 11         | RW          | 0x0                | drv_sel<br>drv select                                                                                                                   |
| 10:3       | RW          | 0x00               | drv_delaynum<br>drv delaynum                                                                                                            |
| 2:1        | RW          | 0x2                | drv_degree<br>drv degree                                                                                                                |
| 0          | RW          | 0x0                | init_state<br>initial state                                                                                                             |

**CRU\_SDIO\_CON1**

Address: Operational Base + offset (0x0150)

SDIO clock generation control register 1

| <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:11      | RO          | 0x0                | reserved                                                                                                                                |
| 10         | RW          | 0x0                | sample_sel<br>sample select                                                                                                             |
| 9:2        | RW          | 0x00               | sample_delaynum<br>sample delaynum                                                                                                      |
| 1:0        | RW          | 0x0                | sample_degree<br>sample degree                                                                                                          |

**CRU\_EMMC\_CON0**

Address: Operational Base + offset (0x0154)

EMMC clock generation control register 0

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>           |
|------------|-------------|--------------------|------------------------------|
| 11         | RW          | 0x0                | drv_sel<br>drv select        |
| 10:3       | RW          | 0x00               | drv_delaynum<br>drv delaynum |
| 2:1        | RW          | 0x2                | drv_degree<br>drv degree     |
| 0          | RW          | 0x0                | init_state<br>initial state  |

**CRU\_EMMC\_CON1**

Address: Operational Base + offset (0x0158)

EMMC clock generation control register 1

| <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:11      | RO          | 0x0                | reserved                                                                                                                                |
| 10         | RW          | 0x0                | sample_sel<br>sample select                                                                                                             |
| 9:2        | RW          | 0x00               | sample_delaynum<br>sample delaynum                                                                                                      |
| 1:0        | RW          | 0x0                | sample_degree<br>sample degree                                                                                                          |

**CRU\_RST\_ST**

Address: Operational Base + offset (0x0160)

WDT and global reset status

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                    |
|------------|-------------|--------------------|-------------------------------------------------------|
| 31:4       | RO          | 0x0                | reserved                                              |
| 3          | RO          | 0x0                | wdt_glb_na_srstn_st<br>second watch dog reset request |
| 2          | RO          | 0x0                | wdt_glb_srstn_st<br>watch dog first reset request     |
| 1          | RO          | 0x0                | glb_na_srstn_st<br>second globle reset request        |
| 0          | RO          | 0x0                | glb_srstn_st<br>first global reset request            |

**CRU\_PLL\_MASK\_CON**

Address: Operational Base + offset (0x01f0)

PLL mask control register

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

| Bit  | Attr | Reset Value | Description                                                                                                         |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------|
| 15:0 | RW   | 0x5a5a      | pll_mask_con<br>When pll_mask_con = 0x5a5a, PLL_CON register would be Read_Write , otherwise it would be Read Only. |

## 3.7 Timing Diagram

Power on reset timing is shown as follow:

Fig. 3-4 Chip Power On Reset Timing Diagram

Npor is hardware reset signal from out-chip, which is filtered glitch to obtain signal sysrstn. To make PLLs work normally, the PLL reset signal (pllrstn) must maintain high for more than 1us, and PLLs start to lock when pllrstn de-assert, and the PLL max lock time is 1500 PLL REFCLK cycles. And then the system will wait about 138us, and then de-assert reset signal chiprstn. The signal chiprstn is used to generate output clocks in CRU. After CRU start output clocks, the system waits again for 512cycles (21.3us) to de-assert signal rstn\_pre, which is used to generate power on reset of all IPs.

## 3.8 Application Notes

### 3.8.1 PLL usage

The chip uses 2.4GHz for all three PLLs (ARM PLL, DDR PLL and GENERAL PLL).

#### A. PLL output frequency configuration

FBDIV, POSTDIV1, BYPASS can be configured by programming CRU\_APLL\_CON0, CRU\_DPLL\_CON0 and CRU\_GPLL\_CON0.

DSMPD, REFDIV, POSTDIV2 can be configured by programming CRU\_APLL\_CON1, CRU\_DPLL\_CON1 and CRU\_GPLL\_CON1.

FRAC can be configured by programming CRU\_APLL\_CON2, CRU\_DPLL\_CON2 and CRU\_GPLL\_CON2.

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

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

$$\text{FOUTPOSTDIV} = \text{FOUTVCO} / \text{POSTDIV1} / \text{POSTDIV2}$$

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

$$\begin{aligned} \text{DSMPD} &= 1 \\ \text{REFDIV} &= 6 \\ \text{FBDIV} &= 175 \\ \text{POSTDIV1} &= 1 \\ \text{POSTDIV2} &= 1 \end{aligned}$$

And then

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

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

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

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

$$\text{FOUTPOSTDIV} = \text{FOUTVCO} / \text{POSTDIV1} / \text{POSTDIV2}$$

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

$$\begin{aligned} \text{DSMPD} &= 0 \\ \text{REFDIV} &= 1 \\ \text{FBDIV} &= 40 \\ \text{FRAC} &= 24'hf5c28f \\ \text{POSTDIV1} &= 2 \\ \text{POSTDIV2} &= 1 \end{aligned}$$

And then

$$\text{FOUTVCO} = \text{FREF} / \text{REFDIV} * (\text{FBDIV} + \text{FRAC} / 224) = 24/1*(40+24'hf5c28f /224)= 983.04$$

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

#### B. PLL frequency range requirement

All the value range requirements are as follow.

|                                                 |                  |
|-------------------------------------------------|------------------|
| FREF(Input Frequency Range in Integer Mode):    | 1MHz to 800MHz   |
| FREF(Input Frequency Range in Fractional Mode): | 10MHz to 800MHz  |
| FREF/REFDIV(The divided reference frequency):   | 1 to 50MHz       |
| FOUTVCO:                                        | 600MHz to 2.4GHz |

### C. PLL setting consideration

- If the POSTDIV value is changed during operation a short pulse (glitch) may occur on FOUTPOSTDIV. The minimum width of the short pulse will be equal to twice the period of the VCO. Therefore, if the circuitry clocked by the PLL is sensitive to short pulses, the new divide value should be re-timed so that it is synchronous with the rising edge of the output clock (FOUTPOSTDIV). Glitches cannot occur on any of the other outputs.
- For lowest power operation, the minimum VCO and FREF frequencies should be used. For minimum jitter operation, the highest VCO and FREF frequencies should be used. The normal operating range for the VCO is described above in .
- The supply rejection will be worse at the low end of the VCO range so care should be taken to keep the supply clean for low power applications.
- The feedback divider is not capable of dividing by all possible settings due to the use of a power-saving architecture. The following settings are valid for FBDIV:
- DSMPD=1 (Integer Mode):
- 12,13,14,16-4095 (practical value is limited to 3200, 2400, or 1600 (FVCOMAX / FREFMIN))
- DSMPD=0 (Fractional Mode):
- 19-4091 (practical value is limited to 320, 240, or 160 (FVCOMAX / FREFMIN))
- The PD input places the PLL into the lowest power mode. In this case, all analog circuits are turned off and FREF will be "ignored". The FOUTPOSTDIV and FOUTVCO pins are forced to logic low (0V).
- The BYPASS pin controls a mux which selects FREF to be passed to the FOUTPOSTDIV when active high. However, the PLL continues to run as it normally would if bypass were low. This is a useful feature for PLL testing since the clock path can be verified without the PLL being required to work. Also, the effect that the PLL induced supply noise has on the output buffering can be evaluated. It is not recommended to switch between BYPASS mode and normal mode for regular chip operation since this may result in a glitch. Also, FOUTPOSTDIVPD should be set low if the PLL is to be used in BYPASS mode.

### 3.8.2 PLL frequency change and lock check

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

PLL lock state can be checked in CRU\_APLL\_CON1[10], CRU\_DPLL\_CON1[10], CRU\_GPLL\_CON1[10] register. The lock state is high when both original hardware PLL lock and PLL counter lock are high. The PLL counter lock initial value is CRU\_GLB\_CNT\_TH[31:16]. The max delay time is 1500 REF\_CLK.

PLL locking consists of three phases.

- Phase 1 is control voltage slewing. During this phase one of the clocks (reference or divide) is much faster than the other, and the PLL frequency adjusts almost continuously. When locking from power down, the divide clock is initially very slow and steadily increases frequency. Slew time is about 2~5s. It will take slightly longer for faster VCO settings when locking from power down, since the PLL must slew further.
- Phase 2 is small signal phase acquisition. During this phase, the internal up/down signals alternate semi-chaotically as the phase slowly adjusts until the two signals are aligned. The duration of this phase depends on the loop bandwidth and is faster with higher bandwidth. Bandwidth can be estimated as FREF / REFDIV / 20 for integer mode and FREF /REFDIV / 40 for fractional mode. The duration of small signal locking is about 1/Bandwidth.
- Phase 3 is the digital cycle count. After the last cycle slip is detected, an internal counter waits 256 FREF / REFDIV cycles before the lock signal goes high. This is frequently the dominant factor in lock time – especially for slower reference clock signals or large reference divide settings. This time can be calculated as 256\*REFDIV/FREF.

### **3.8.3 Fractional divider usage**

To get specific frequency, clocks of I2S, SPDIF, UART can be generated by fractional divider. Generally you must set that denominator is 20 times larger than numerator to generate precise clock frequency. So the fractional divider applies only to generate low frequency clock like I2S, UART.

### **3.8.4 Global software reset**

Two global software resets are designed in the chip, you can program CRU\_GLB\_SRST\_FST\_VALUE[15:0] as 0fdb9 to assert the first global software reset glb\_srstn\_1 and program CRU\_GLB\_SRST\_SND\_VALUE[15:0] as 0eca8 to assert the second global software reset glb\_srstn\_2. These two software resets are self-deasserted by hardware.

Glb\_srstn\_1 resets almost all logic.

Glb\_srstn\_2 resets almost all logic except GRF and GPIOs.

## Chapter 4 Embedded Processor (Cortex-A7)

### 4.1 Overview

The Cortex-A7 MP subsystem of the device is based on the symmetric multiprocessor (SMP) architecture, thus the Dual Cortex-A7 MPU subsystem delivers higher performance and optimal power management, debug and emulation capabilities.

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

The key features of the Cortex-A7 MP subsystem include:

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

### 4.2 Block Diagram



Fig. 4-1 MP Subsystem architecture

### 4.3 Function Description

Please refer to the document Cortex-A7\_MPCore\_Technical\_Reference\_Manual.pdf for the CPU detail description.

### 4.4 Register Description

Please refer to the document Cortex-A7\_MPCore\_Technical\_Reference\_Manual.pdf for the CPU detail description.

## Chapter 5 General Register Files (GRF)

### 5.1 Overview

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

### 5.2 Function Description

The function of general register file is:

- IOMUX control
- GPIO PAD pulldown and pullup control
- Common system control
- Record the system state

### 5.3 Register Description

#### 5.3.1 Registers Summary

| Name             | Offset | Size | Reset Value | Description                        |
|------------------|--------|------|-------------|------------------------------------|
| GRF_GPIO0A_IOMUX | 0x00a8 | W    | 0x00000000  | GPIO0A iomux control               |
| GRF_GPIO0B_IOMUX | 0x00ac | W    | 0x00000000  | GPIO0B iomux control               |
| GRF_GPIO0C_IOMUX | 0x00b0 | W    | 0x00000000  | GPIO0C iomux control               |
| GRF_GPIO0D_IOMUX | 0x00b4 | W    | 0x00000000  | GPIO0D iomux control               |
| GRF_GPIO1A_IOMUX | 0x00b8 | W    | 0x00000000  | GPIO1A iomux control               |
| GRF_GPIO1B_IOMUX | 0x00bc | W    | 0x00000000  | GPIO1B iomux control               |
| GRF_GPIO1C_IOMUX | 0x00c0 | W    | 0x00000000  | GPIO1C iomux control               |
| GRF_GPIO1D_IOMUX | 0x00c4 | W    | 0x00000000  | GPIO1D iomux control               |
| GRF_GPIO2A_IOMUX | 0x00c8 | W    | 0x00000000  | GPIO2A iomux control               |
| GRF_GPIO2B_IOMUX | 0x00cc | W    | 0x00000000  | GPIO2B iomux control               |
| GRF_GPIO2C_IOMUX | 0x00d0 | W    | 0x00000000  | GPIO2C iomux control               |
| GRF_GPIO2D_IOMUX | 0x00d4 | W    | 0x00000000  | GPIO2D iomux control               |
| GRF_GPIO_DS      | 0x0100 | W    | 0x00000000  | GPIO DS control                    |
| GRF_GPIO0L_PULL  | 0x0118 | W    | 0x00000000  | GPIO0A/GPIO0B pull up/down control |
| GRF_GPIO0H_PULL  | 0x011c | W    | 0x00000000  | GPIO0C/GPIO0D pull up/down control |
| GRF_GPIO1L_PULL  | 0x0120 | W    | 0x00000000  | GPIO1A/GPIO1B pull up/down control |
| GRF_GPIO1H_PULL  | 0x0124 | W    | 0x00000000  | GPIO1C/GPIO1D pull up/down control |
| GRF_GPIO2L_PULL  | 0x0128 | W    | 0x00000000  | GPIO2A/GPIO2B pull up/down control |
| GRF_GPIO2H_PULL  | 0x012c | W    | 0x00000000  | GPIO2C/GPIO2D pull up/down control |
| GRF_SOC_CON0     | 0x0140 | W    | 0x00000820  | SoC control register 0             |
| GRF_SOC_CON1     | 0x0144 | W    | 0x00000000  | SoC control register 1             |
| GRF_SOC_CON2     | 0x0148 | W    | 0x00000082  | SoC control register 2             |
| GRF_SOC_STATUS0  | 0x014c | W    | 0x00000800  | SoC status register 0              |

| <b>Name</b>      | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>            |
|------------------|---------------|-------------|--------------------|-------------------------------|
| GRF_SOC_CON3     | 0x0154        | W           | 0x00001f86         | SoC control register 3        |
| GRF_UOC0_CON5    | 0x017c        | W           | 0x00000000         | OTG control register          |
| GRF_UOC1_CON4    | 0x0190        | W           | 0x00000001c        | USB HOST 2.0 control register |
| GRF_UOC1_CON5    | 0x0194        | W           | 0x000000000        | USB HOST 2.0 control register |
| GRF_DDRC_STAT    | 0x019c        | W           | 0x00180000         | DDRC status register          |
| GRF_UOC_CON6     | 0x01a0        | W           | 0x000042a0         | USB control register          |
| GRF_SOC_STATUS1  | 0x01a4        | W           | 0x000000000        | SoC status register 1         |
| GRF_CPU_CON0     | 0x01a8        | W           | 0x00002002         | CPU control register 0        |
| GRF_CPU_CON1     | 0x01ac        | W           | 0x000000000        | CPU control register 1        |
| GRF_CPU_CON2     | 0x01b0        | W           | 0x00000003f        | CPU control register 2        |
| GRF_CPU_STATUS0  | 0x01c0        | W           | 0x000000006        | CPU status register 0         |
| GRF_CPU_STATUS1  | 0x01c4        | W           | 0x000000000        | CPU status register 2         |
| GRF_OS_REG0      | 0x01c8        | W           | 0x000000000        | Software OS register 0        |
| GRF_OS_REG1      | 0x01cc        | W           | 0x000000000        | Software OS register 1        |
| GRF_OS_REG2      | 0x01d0        | W           | 0x000000000        | Software OS register 2        |
| GRF_OS_REG3      | 0x01d4        | W           | 0x000000000        | Software OS register 3        |
| GRF_OS_REG4      | 0x01d8        | W           | 0x000000000        | Software OS register 4        |
| GRF_OS_REG5      | 0x01dc        | W           | 0x000000000        | Software OS register 5        |
| GRF_OS_REG6      | 0x01e0        | W           | 0x000000000        | Software OS register 6        |
| GRF_OS_REG7      | 0x01e4        | W           | 0x000000000        | Software OS register 7        |
| GRF_PVTM_CON0    | 0x0200        | W           | 0x000000000        | PVTM control register 0       |
| GRF_PVTM_CON1    | 0x0204        | W           | 0x000000000        | PVTM control register 1       |
| GRF_PVTM_CON2    | 0x0208        | W           | 0x000000000        | PVTM control register 2       |
| GRF_PVTM_CON3    | 0x020c        | W           | 0x000000000        | PVTM control register 3       |
| GRF_PVTM_STATUS0 | 0x0210        | W           | 0x000000000        | PVTM status register 0        |
| GRF_PVTM_STATUS1 | 0x0214        | W           | 0x000000000        | PVTM status register 1        |
| GRF_PVTM_STATUS2 | 0x0218        | W           | 0x000000000        | PVTM status register 2        |
| GRF_PVTM_STATUS3 | 0x021c        | W           | 0x000000000        | PVTM status register 3        |
| GRF_DFI_WRNUM    | 0x0220        | W           | 0x000000000        | DFI write number register     |
| GRF_DFI_RDNUM    | 0x0224        | W           | 0x000000000        | DFI read number register      |
| GRF_DFI_ACTNUM   | 0x0228        | W           | 0x000000000        | DFI active number register    |
| GRF_DFI_TIMERVAL | 0x022c        | W           | 0x000000000        | DFI work time                 |
| GRF_NIF_FIFO0    | 0x0230        | W           | 0x000000000        | NIF status register 0         |
| GRF_NIF_FIFO1    | 0x0234        | W           | 0x000000000        | NIF status register 1         |
| GRF_NIF_FIFO2    | 0x0238        | W           | 0x000000000        | NIF status register 2         |
| GRF_NIF_FIFO3    | 0x023c        | W           | 0x000000000        | NIF status register 3         |
| GRF_USBPHY0_CON0 | 0x0280        | W           | 0x00008618         | usbphy control register       |
| GRF_USBPHY0_CON1 | 0x0284        | W           | 0x0000e007         | usbphy control register       |
| GRF_USBPHY0_CON2 | 0x0288        | W           | 0x000082aa         | usbphy control register       |
| GRF_USBPHY0_CON3 | 0x028c        | W           | 0x00000200         | usbphy control register       |
| GRF_USBPHY0_CON4 | 0x0290        | W           | 0x00000002         | usbphy control register       |
| GRF_USBPHY0_CON5 | 0x0294        | W           | 0x000000000        | usbphy control register       |
| GRF_USBPHY0_CON6 | 0x0298        | W           | 0x000000004        | usbphy control register       |
| GRF_USBPHY0_CON7 | 0x029c        | W           | 0x000068c0         | usbphy control register       |

| Name              | Offset | Size | Reset Value | Description                   |
|-------------------|--------|------|-------------|-------------------------------|
| GRF_USBPHY1_CON0  | 0x02a0 | W    | 0x00008618  | usbphy control register       |
| GRF_USBPHY1_CON1  | 0x02a4 | W    | 0x0000e007  | usbphy control register       |
| GRF_USBPHY1_CON2  | 0x02a8 | W    | 0x000082aa  | usbphy control register       |
| GRF_USBPHY1_CON3  | 0x02ac | W    | 0x00000200  | usbphy control register       |
| GRF_USBPHY1_CON4  | 0x02b0 | W    | 0x00000002  | usbphy control register       |
| GRF_USBPHY1_CON5  | 0x02b4 | W    | 0x00000000  | usbphy control register       |
| GRF_USBPHY1_CON6  | 0x02b8 | W    | 0x00000004  | usbphy control register       |
| GRF_USBPHY1_CON7  | 0x02bc | W    | 0x000068c0  | usbphy control register       |
| GRF_CHIP_TAG      | 0x0300 | W    | 0x00003012  | chip tag register             |
| GRF_SDMMC_DET_CNT | 0x0304 | W    | 0x00000cff  | SDMMC detectn filter count    |
| GRF_EFUSE_PRG     | 0x037c | W    | 0x00000000  | eFuse program enable register |

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

### 5.3.2 Detail Register Description

#### GRF\_GPIO0A\_IOMUX

Address: Operational Base + offset (0x00a8)

GPIO0A iomux control

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                      |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0x0000      | write_enable<br>bit0~15 write enable<br>When bit 16=1, bit 0 can be written by software;<br>When bit 16=0, bit 0 cannot be written by software;<br>When bit 17=1, bit 1 can be written by software;<br>When bit 17=0, bit 1 cannot be written by software;<br>.....<br>When bit 31=1, bit 15 can be written by software;<br>When bit 31=0, bit 15 cannot be written by software. |
| 15:7  | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                         |
| 6     | RW   | 0x0         | gpio0a3_sel<br>GPIO0A[3] iomux select<br>2'b01: i2c1_sda<br>2'b00: gpio                                                                                                                                                                                                                                                                                                          |
| 5     | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                         |
| 4     | RW   | 0x0         | gpio0a2_sel<br>GPIO0A[2] iomux select<br>2'b01: i2c1_scl<br>2'b00: gpio                                                                                                                                                                                                                                                                                                          |
| 3:2   | RW   | 0x0         | gpio0a1_sel<br>GPIO0A[1] iomux select<br>2'b10: pwm2<br>2'b01: i2c0_sda<br>2'b00: gpio                                                                                                                                                                                                                                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------|
| 1:0        | RW          | 0x0                | gpio0a0_sel<br>GPIO0A[0] iomux select<br>2'b10: pwm1<br>2'b01: i2c0_scl<br>2'b00: gpio |

**GRF\_GPIOOB\_IOMUX**

Address: Operational Base + offset (0x00ac)

GPIO0B iomux control

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_enable<br>bit0~15 write enable<br>When bit 16=1, bit 0 can be written by software;<br>When bit 16=0, bit 0 cannot be written by software;<br>When bit 17=1, bit 1 can be written by software;<br>When bit 17=0, bit 1 cannot be written by software;<br>.....<br>When bit 31=1, bit 15 can be written by software;<br>When bit 31=0, bit 15 cannot be written by software. |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                         |
| 13:12      | RW          | 0x0                | gpio0b6_sel<br>GPIO0B[6] iomux select<br>2'b10: i2s1_sclk<br>2'b01: mmc1_d3<br>2'b00: gpio                                                                                                                                                                                                                                                                                       |
| 11:10      | RW          | 0x0                | gpio0b5_sel<br>GPIO0B[5] iomux select<br>2'b10: i2s1_sdi<br>2'b01: mmc1_d2<br>2'b00: gpio                                                                                                                                                                                                                                                                                        |
| 9:8        | RW          | 0x0                | gpio0b4_sel<br>GPIO0B[4] iomux select<br>2'b10: i2s1_lrcktx<br>2'b01: mmc1_d1<br>2'b00: gpio                                                                                                                                                                                                                                                                                     |
| 7:6        | RW          | 0x0                | gpio0b3_sel<br>GPIO0B[3] iomux select<br>2'b10: i2s1_lrckrx<br>2'b01: mmc1_d0<br>2'b00: gpio                                                                                                                                                                                                                                                                                     |
| 5:4        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                         |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                             |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------|
| 3:2        | RW          | 0x0                | gpio0b1_sel<br>GPIO0B[1] iomux select<br>2'b10: i2s1_mclk<br>2'b01: mmc1_clkout<br>2'b00: gpio |
| 1:0        | RW          | 0x0                | gpio0b0_sel<br>GPIO0B[0] iomux select<br>2'b10: i2s1_sdo<br>2'b01: mmc1_cmd<br>2'b00: gpio     |

**GRF\_GPIOOC\_IOMUX**

Address: Operational Base + offset (0x00b0)

GPIO0C iomux control

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_enable<br>bit0~15 write enable<br>When bit 16=1, bit 0 can be written by software;<br>When bit 16=0, bit 0 cannot be written by software;<br>When bit 17=1, bit 1 can be written by software;<br>When bit 17=0, bit 1 cannot be written by software;<br>.....<br>When bit 31=1, bit 15 can be written by software;<br>When bit 31=0, bit 15 cannot be written by software. |
| 15:9       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                         |
| 8          | RW          | 0x0                | gpio0c4_sel<br>GPIO0C[4] iomux select<br>1'b1: drive_vbus<br>1'b0: gpio                                                                                                                                                                                                                                                                                                          |
| 7          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                         |
| 6          | RW          | 0x0                | gpio0c3_sel<br>GPIO0C[3] iomux select<br>1'b1: uart0_ctsn<br>1'b0: gpio                                                                                                                                                                                                                                                                                                          |
| 5          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                         |
| 4          | RW          | 0x0                | gpio0c2_sel<br>GPIO0C[2] iomux select<br>1'b1: uart0_rtsn<br>1'b0: gpio                                                                                                                                                                                                                                                                                                          |
| 3          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                         |
| 2          | RW          | 0x0                | gpio0c1_sel<br>GPIO0C[1] iomux select<br>1'b1: uart0_sin<br>1'b0: gpio                                                                                                                                                                                                                                                                                                           |
| 1          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                         |

| Bit | Attr | Reset Value | Description                                                             |
|-----|------|-------------|-------------------------------------------------------------------------|
| 0   | RW   | 0x0         | gpio0c0_sel<br>GPIO0C[0] iomux select<br>1'b1: uart0_sout<br>1'b0: gpio |

**GRF\_GPIO0D\_IOMUX**

Address: Operational Base + offset (0x00b4)

GPIO0D iomux control

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                      |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0x0000      | write_enable<br>bit0~15 write enable<br>When bit 16=1, bit 0 can be written by software;<br>When bit 16=0, bit 0 cannot be written by software;<br>When bit 17=1, bit 1 can be written by software;<br>When bit 17=0, bit 1 cannot be written by software;<br>.....<br>When bit 31=1, bit 15 can be written by software;<br>When bit 31=0, bit 15 cannot be written by software. |
| 15:9  | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                         |
| 8     | RW   | 0x0         | gpio0d4_sel<br>GPIO0D[4] iomux select<br>1'b1: spdif<br>1'b0: gpio                                                                                                                                                                                                                                                                                                               |
| 7     | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                         |
| 6     | RW   | 0x0         | gpio0d3_sel<br>GPIO0D[3] iomux select<br>1'b1: pwm3(IR)<br>1'b0: gpio                                                                                                                                                                                                                                                                                                            |
| 5     | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                         |
| 4     | RW   | 0x0         | gpio0d2_sel<br>GPIO0D[2] iomux select<br>1'b1: pwm0<br>1'b0: gpio                                                                                                                                                                                                                                                                                                                |
| 3:0   | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                         |

**GRF\_GPIO1A\_IOMUX**

Address: Operational Base + offset (0x00b8)

GPIO1A iomux control

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

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                      |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0x0000      | write_enable<br>bit0~15 write enable<br>When bit 16=1, bit 0 can be written by software;<br>When bit 16=0, bit 0 cannot be written by software;<br>When bit 17=1, bit 1 can be written by software;<br>When bit 17=0, bit 1 cannot be written by software;<br>.....<br>When bit 31=1, bit 15 can be written by software;<br>When bit 31=0, bit 15 cannot be written by software. |
| 15:11 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                         |
| 10    | RW   | 0x0         | gpio1a5_sel<br>GPIO1A[5] iomux select<br>1'b1: i2s_sdi<br>1'b0: gpio                                                                                                                                                                                                                                                                                                             |
| 9     | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                         |
| 8     | RW   | 0x0         | gpio1a4_sel<br>GPIO1A[4] iomux select<br>1'b1: i2s_sdo<br>1'b0: gpio                                                                                                                                                                                                                                                                                                             |
| 7     | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                         |
| 6     | RW   | 0x0         | gpio1a3_sel<br>GPIO1A[3] iomux select<br>1'b1: i2s_lrcktx<br>1'b0: gpio                                                                                                                                                                                                                                                                                                          |
| 5:4   | RW   | 0x0         | gpio1a2_sel<br>GPIO1A[2] iomux select<br>2'b10: pwm1_0<br>2'b01: i2s_lrckrx<br>2'b00: gpio                                                                                                                                                                                                                                                                                       |
| 3     | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                         |
| 2     | RW   | 0x0         | gpio1a1_sel<br>GPIO1A[1] iomux select<br>1'b1: i2s_sclk<br>1'b0: gpio                                                                                                                                                                                                                                                                                                            |
| 1     | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                         |
| 0     | RW   | 0x0         | gpio1a0_sel<br>GPIO1A[0] iomux select<br>1'b1: i2s_mclk<br>1'b0: gpio                                                                                                                                                                                                                                                                                                            |

**GRF\_GPIO1B\_IOMUX**

Address: Operational Base + offset (0x00bc)

GPIO1B iomux control

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

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                      |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0x0000      | write_enable<br>bit0~15 write enable<br>When bit 16=1, bit 0 can be written by software;<br>When bit 16=0, bit 0 cannot be written by software;<br>When bit 17=1, bit 1 can be written by software;<br>When bit 17=0, bit 1 cannot be written by software;<br>.....<br>When bit 31=1, bit 15 can be written by software;<br>When bit 31=0, bit 15 cannot be written by software. |
| 15    | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                         |
| 14    | RW   | 0x0         | gpio1b7_sel<br>GPIO1B[7] iomux select<br>1'b1: mmc0_cmd<br>1'b0: gpio                                                                                                                                                                                                                                                                                                            |
| 13:7  | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                         |
| 6     | RW   | 0x0         | gpio1b3_sel<br>GPIO1B[3] iomux select<br>1'b1: hdmi_hpd<br>1'b0: gpio                                                                                                                                                                                                                                                                                                            |
| 5     | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                         |
| 4     | RW   | 0x0         | gpio1b2_sel<br>GPIO1B[2] iomux select<br>1'b1: hdmi_scl<br>1'b0: gpio                                                                                                                                                                                                                                                                                                            |
| 3     | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                         |
| 2     | RW   | 0x0         | gpio1b1_sel<br>GPIO1B[1] iomux select<br>1'b1: hdmi_sda<br>1'b0: gpio                                                                                                                                                                                                                                                                                                            |
| 1     | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                         |
| 0     | RW   | 0x0         | gpio1b0_sel<br>GPIO1B[0] iomux select<br>1'b1: hdmi_cec<br>1'b0: gpio                                                                                                                                                                                                                                                                                                            |

**GRF\_GPIO1C\_IOMUX**

Address: Operational Base + offset (0x00c0)

GPIO1C iomux control

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_enable<br>bit0~15 write enable<br>When bit 16=1, bit 0 can be written by software;<br>When bit 16=0, bit 0 cannot be written by software;<br>When bit 17=1, bit 1 can be written by software;<br>When bit 17=0, bit 1 cannot be written by software;<br>.....<br>When bit 31=1, bit 15 can be written by software;<br>When bit 31=0, bit 15 cannot be written by software. |
| 15:12      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                         |
| 11:10      | RW          | 0x0                | gpio1c5_sel<br>GPIO1C[5] iomux select<br>2'b10: jtag_tms when sdmmc0_detectn is invalid<br>2'b01: mmc0_d3<br>2'b00: gpio                                                                                                                                                                                                                                                         |
| 9:8        | RW          | 0x0                | gpio1c4_sel<br>GPIO1C[4] iomux select<br>2'b10: jtag_tck when sdmmc0_detectn is invalid<br>2'b01: mmc0_d2<br>2'b00: gpio                                                                                                                                                                                                                                                         |
| 7:6        | RW          | 0x0                | gpio1c3_sel<br>GPIO1C[3] iomux select<br>2'b10: uart2_sout<br>2'b01: mmc0_d1<br>2'b00: gpio                                                                                                                                                                                                                                                                                      |
| 5:4        | RW          | 0x0                | gpio1c2_sel<br>GPIO1C[2] iomux select<br>2'b10:uart2_sin<br>2'b01:mmc0_d0<br>2'b00:gpio                                                                                                                                                                                                                                                                                          |
| 3          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                         |
| 2          | RW          | 0x0                | gpio1c1_sel<br>GPIO1C[1] iomux select<br>1'b1: mmc0_detn<br>1'b0: gpio                                                                                                                                                                                                                                                                                                           |
| 1          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                         |
| 0          | RW          | 0x0                | gpio1c0_sel<br>GPIO1C[0] iomux select<br>1'b1: mmc0_clkout<br>1'b0: gpio                                                                                                                                                                                                                                                                                                         |

**GRF\_GPIO1D\_IOMUX**

Address: Operational Base + offset (0x00c4)

GPIO1D iomux control

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | <p>write_enable<br/>bit0~15 write enable<br/>When bit 16=1, bit 0 can be written by software;<br/>When bit 16=0, bit 0 cannot be written by software;<br/>When bit 17=1, bit 1 can be written by software;<br/>When bit 17=0, bit 1 cannot be written by software;<br/>.....<br/>When bit 31=1, bit 15 can be written by software;<br/>When bit 31=0, bit 15 cannot be written by software.</p> |
| 15:14      | RW          | 0x0                | <p>gpio1d7_sel<br/>GPIO1D[7] iomux select<br/>2'b11: spi_csn1<br/>2'b10: emmc_d7<br/>2'b01: nand_d7<br/>2'b00: gpio</p>                                                                                                                                                                                                                                                                         |
| 13:12      | RW          | 0x0                | <p>gpio1d6_sel<br/>GPIO1D[6] iomux select<br/>2'b11: spi_csn0<br/>2'b10: emmc_d6<br/>2'b01: nand_d6<br/>2'b00: gpio</p>                                                                                                                                                                                                                                                                         |
| 11:10      | RW          | 0x0                | <p>gpio1d5_sel<br/>GPIO1D[5] iomux select<br/>2'b11: spi_txd<br/>2'b10: emmc_d5<br/>2'b01: nand_d5<br/>2'b00: gpio</p>                                                                                                                                                                                                                                                                          |
| 9:8        | RW          | 0x0                | <p>gpio1d4_sel<br/>GPIO1D[4] iomux select<br/>2'b11: spi_rxd<br/>2'b10: emmc_d4<br/>2'b01: nand_d4<br/>2'b00: gpio</p>                                                                                                                                                                                                                                                                          |
| 7:6        | RW          | 0x0                | <p>gpio1d3_sel<br/>GPIO1D[3] iomux select<br/>2'b11: sfc_sio3<br/>2'b10: emmc_d3<br/>2'b01: nand_d3<br/>2'b00: gpio</p>                                                                                                                                                                                                                                                                         |
| 5:4        | RW          | 0x0                | <p>gpio1d2_sel<br/>GPIO1D[2] iomux select<br/>2'b11: sfc_sio2<br/>2'b10: emmc_d2<br/>2'b01: nand_d2<br/>2'b00: gpio</p>                                                                                                                                                                                                                                                                         |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------|
| 3:2        | RW          | 0x0                | gpio1d1_sel<br>GPIO1D[1] iomux select<br>2'b11: sfc_sio1<br>2'b10: emmc_d1<br>2'b01: nand_d1<br>2'b00: gpio |
| 1:0        | RW          | 0x0                | gpio1d0_sel<br>GPIO1D[0] iomux select<br>2'b11: sfc_sio0<br>2'b10: emmc_d0<br>2'b01: nand_d0<br>2'b00: gpio |

**GRF\_GPIO2A\_IOMUX**

Address: Operational Base + offset (0x00c8)

GPIO2A iomux control

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_enable<br>bit0~15 write enable<br>When bit 16=1, bit 0 can be written by software;<br>When bit 16=0, bit 0 cannot be written by software;<br>When bit 17=1, bit 1 can be written by software;<br>When bit 17=0, bit 1 cannot be written by software;<br>.....<br>When bit 31=1, bit 15 can be written by software;<br>When bit 31=0, bit 15 cannot be written by software. |
| 15         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                         |
| 14         | RW          | 0x0                | gpio2a7_sel<br>GPIO2A[7] iomux select<br>1'b1: testclk_out<br>1'b0: gpio                                                                                                                                                                                                                                                                                                         |
| 13         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                         |
| 12         | RW          | 0x0                | gpio2a6_sel<br>GPIO2A[6] iomux select<br>1'b1: nand_cs0<br>1'b0: gpio                                                                                                                                                                                                                                                                                                            |
| 11:10      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                         |
| 9:8        | RW          | 0x0                | gpio2a4_sel<br>GPIO2A[4] iomux select<br>2'b11: sfc_clk<br>2'b10: emmc_cmd<br>2'b01: nand_rdy<br>2'b00: gpio                                                                                                                                                                                                                                                                     |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                            |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------|
| 7:6        | RW          | 0x0                | gpio2a3_sel<br>GPIO2A[3] iomux select<br>2'b10: sfc_csn1<br>2'b01: nand_rdn<br>2'b00: gpio    |
| 5:4        | RW          | 0x0                | gpio2a2_sel<br>GPIO2A[2] iomux select<br>2'b10: sfc_csn0<br>2'b01: nand_wrn<br>2'b00: gpio    |
| 3:2        | RW          | 0x0                | gpio2a1_sel<br>GPIO2A[1] iomux select<br>2'b10: emmc_clkout<br>2'b01: nand_cle<br>2'b00: gpio |
| 1:0        | RW          | 0x0                | gpio2a0_sel<br>GPIO2A[0] iomux select<br>2'b10: spi_clk<br>2'b01: nand_ale<br>2'b00: gpio     |

**GRF\_GPIO2B\_IOMUX**

Address: Operational Base + offset (0x00cc)

GPIO2B iomux control

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_enable<br>bit0~15 write enable<br>When bit 16=1, bit 0 can be written by software;<br>When bit 16=0, bit 0 cannot be written by software;<br>When bit 17=1, bit 1 can be written by software;<br>When bit 17=0, bit 1 cannot be written by software;<br>.....<br>When bit 31=1, bit 15 can be written by software;<br>When bit 31=0, bit 15 cannot be written by software. |
| 15         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                         |
| 14         | RW          | 0x0                | gpio2b7_sel<br>GPIO2B[7] iomux select<br>1'b1: mac_rxer<br>1'b0: gpio                                                                                                                                                                                                                                                                                                            |
| 13:12      | RW          | 0x0                | gpio2b6_sel<br>GPIO2B[6] iomux select<br>2'b10: mac_clkin<br>2'b01: mac_clkout<br>2'b00: gpio                                                                                                                                                                                                                                                                                    |
| 11         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                         |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------|
| 10         | RW          | 0x0                | gpio2b5_sel<br>GPIO2B[5] iomux select<br>1'b1: mac_txen<br>1'b0: gpio |
| 9          | RO          | 0x0                | reserved                                                              |
| 8          | RW          | 0x0                | gpio2b4_sel<br>GPIO2B[4] iomux select<br>1'b1: mac_mdio<br>1'b0: gpio |
| 7:5        | RO          | 0x0                | reserved                                                              |
| 4          | RW          | 0x0                | gpio2b2_sel<br>GPIO2B[2] iomux select<br>1'b1: mac_crs<br>1'b0: gpio  |
| 3:0        | RO          | 0x0                | reserved                                                              |

**GRF\_GPIO2C\_IOMUX**

Address: Operational Base + offset (0x00d0)

GPIO2C iomux control

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_enable<br>bit0~15 write enable<br>When bit 16=1, bit 0 can be written by software;<br>When bit 16=0, bit 0 cannot be written by software;<br>When bit 17=1, bit 1 can be written by software;<br>When bit 17=0, bit 1 cannot be written by software;<br>.....<br>When bit 31=1, bit 15 can be written by software;<br>When bit 31=0, bit 15 cannot be written by software. |
| 15:14      | RW          | 0x0                | gpio2c7_sel<br>GPIO2C[7] iomux select<br>2'b10: testclk_out1<br>2'b01: uart1_sout<br>2'b00: gpio                                                                                                                                                                                                                                                                                 |
| 13         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                         |
| 12         | RW          | 0x0                | gpio2c6_sel<br>GPIO2C[6] iomux select<br>1'b1: uart1_sin<br>1'b0: gpio                                                                                                                                                                                                                                                                                                           |
| 11         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                         |
| 10         | RW          | 0x0                | gpio2c5_sel<br>GPIO2C[5] iomux select<br>1'b1: i2c2_scl<br>1'b0: gpio                                                                                                                                                                                                                                                                                                            |
| 9          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                         |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------|
| 8          | RW          | 0x0                | gpio2c4_sel<br>GPIO2C[4] iomux select<br>1'b1: i2c2_sda<br>1'b0: gpio |
| 7          | RO          | 0x0                | reserved                                                              |
| 6          | RW          | 0x0                | gpio2c3_sel<br>GPIO2C[3] iomux select<br>1'b1: mac_txd0<br>1'b0: gpio |
| 5          | RO          | 0x0                | reserved                                                              |
| 4          | RW          | 0x0                | gpio2c2_sel<br>GPIO2C[2] iomux select<br>1'b1: mac_txd1<br>1'b0: gpio |
| 3          | RO          | 0x0                | reserved                                                              |
| 2          | RW          | 0x0                | gpio2c1_sel<br>GPIO2C[1] iomux select<br>1'b1: mac_rxd0<br>1'b0: gpio |
| 1          | RO          | 0x0                | reserved                                                              |
| 0          | RW          | 0x0                | gpio2c0_sel<br>GPIO2C[0] iomux select<br>1'b1: mac_rxd1<br>1'b0: gpio |

**GRF\_GPIO2D\_IOMUX**

Address: Operational Base + offset (0x00d4)

GPIO2D iomux control

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_enable<br>bit0~15 write enable<br>When bit 16=1, bit 0 can be written by software;<br>When bit 16=0, bit 0 cannot be written by software;<br>When bit 17=1, bit 1 can be written by software;<br>When bit 17=0, bit 1 cannot be written by software;<br>.....<br>When bit 31=1, bit 15 can be written by software;<br>When bit 31=0, bit 15 cannot be written by software. |
| 15:13      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                         |
| 12         | RW          | 0x0                | gpio2d6_sel<br>GPIO2D[6] iomux select<br>1'b1: i2s_sdo1<br>1'b0: gpio                                                                                                                                                                                                                                                                                                            |
| 11         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                         |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------|
| 10         | RW          | 0x0                | gpio2d5_sel<br>GPIO2D[5] iomux select<br>1'b1: i2s_sdo2<br>1'b0: gpio |
| 9          | RO          | 0x0                | reserved                                                              |
| 8          | RW          | 0x0                | gpio2d4_sel<br>GPIO2D[4] iomux select<br>1'b1: i2s_sdo3<br>1'b0: gpio |
| 7:3        | RO          | 0x0                | reserved                                                              |
| 2          | RW          | 0x0                | gpio2d1_sel<br>GPIO2D[1] iomux select<br>1'b1: mac_mdc<br>1'b0: gpio  |
| 1:0        | RO          | 0x0                | reserved                                                              |

**GRF\_GPIO\_DS**

Address: Operational Base + offset (0x0100)

GPIO DS control

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>bit0~bit15 write enable<br>When bit 16=1, bit 0 can be written by software;<br>When bit 16=0, bit 0 cannot be written by software;<br>When bit 17=1, bit 1 can be written by software;<br>When bit 17=0, bit 1 cannot be written by software;<br>.....<br>When bit 31=1, bit 15 can be written by software;<br>When bit 31=0, bit 15 cannot be written by software. |
| 15:12      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                            |
| 11:10      | RW          | 0x0                | gpio_1b3_ds<br>driver strength setting<br>2'b00: 2.6mA ~ 6.8mA<br>2'b01: 5.1mA ~ 14mA<br>2'b10: 7.7mA ~ 20mA<br>2'b11: 10mA ~ 27mA                                                                                                                                                                                                                                                  |
| 9:8        | RW          | 0x0                | gpio_1b2_ds<br>driver strength setting<br>2'b00: 2.6mA ~ 6.8mA<br>2'b01: 5.1mA ~ 14mA<br>2'b10: 7.7mA ~ 20mA<br>2'b11: 10mA ~ 27mA                                                                                                                                                                                                                                                  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 7:6        | RW          | 0x0                | gpio_1b1_ds<br>driver strength setting<br>2'b00: 2.6mA ~ 6.8mA<br>2'b01: 5.1mA ~ 14mA<br>2'b10: 7.7mA ~ 20mA<br>2'b11: 10mA ~ 27mA |
| 5:4        | RW          | 0x0                | gpio_1b0_ds<br>driver strength setting<br>2'b00: 2.6mA ~ 6.8mA<br>2'b01: 5.1mA ~ 14mA<br>2'b10: 7.7mA ~ 20mA<br>2'b11: 10mA ~ 27mA |
| 3          | RW          | 0x0                | gpio_1b3_sl<br>Control the slew rata of gpio_1b3<br>1'b0: slow<br>1'b1: fast                                                       |
| 2          | RW          | 0x0                | gpio_1b2_sl<br>Control the slew rata of gpio_1b2<br>1'b0: slow<br>1'b1: fast                                                       |
| 1          | RW          | 0x0                | gpio_1b1_sl<br>Control the slew rata of gpio_1b1<br>1'b0: slow<br>1'b1: fast                                                       |
| 0          | RW          | 0x0                | gpio_1b0_sl<br>Control the slew rata of gpio_1b0<br>1'b0: slow<br>1'b1: fast                                                       |

**GRF\_GPIO0L\_PULL**

Address: Operational Base + offset (0x0118)

GPIO0A/GPIO0B pull up/down control

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

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:8 | RW   | 0x00        | <p>gpio0b_pull<br/>GPIO0B pull up/down enable<br/>Values written to this register independently control Pullup/Pulldown or not for the corresponding data bit in GPIO.<br/>1'b0: pull up/down enable, PAD type will decide to be up or down, not related with this value<br/>1'b1: pull up/down disable<br/>bit8 - GPIO0B[0] pull up/down control<br/>bit9 - GPIO0B[1] pull up/down control<br/>bit10 - GPIO0B[2] pull up/down control<br/>...<br/>bit15 - GPIO0B[7] pull up/down control</p> |
| 7:0  | RW   | 0x00        | <p>gpio0a_pull<br/>GPIO0A pull up/down enable<br/>Values written to this register independently control Pullup/Pulldown or not for the corresponding data bit in GPIO.<br/>1'b0: pull up/down enable, PAD type will decide to be up or down, not related with this value<br/>1'b1: pull up/down disable<br/>bit0 - GPIO0A[0] pull up/down control<br/>bit1 - GPIO0A[1] pull up/down control<br/>bit2 - GPIO0A[2] pull up/down control<br/>...<br/>bit7 - GPIO0A[7] pull up/down control</p>   |

**GRF\_GPIOH\_PULL**

Address: Operational Base + offset (0x011c)

GPIO0C/GPIO0D pull up/down control

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

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:8 | RW   | 0x00        | <p>gpio0d_pull<br/>GPIO0D pull up/down enable<br/>Values written to this register independently control Pullup/Pulldown or not for the corresponding data bit in GPIO.<br/>1'b0: pull up/down enable, PAD type will decide to be up or down, not related with this value<br/>1'b1: pull up/down disable<br/>bit8 - GPIO0D[0] pull up/down control<br/>bit9 - GPIO0D[1] pull up/down control<br/>bit10 - GPIO0D[2] pull up/down control<br/>...<br/>bit15 - GPIO0D[7] pull up/down control</p> |
| 7:0  | RW   | 0x00        | <p>gpio0c_pull<br/>GPIO0C pull up/down enable<br/>Values written to this register independently control Pullup/Pulldown or not for the corresponding data bit in GPIO.<br/>1'b0: pull up/down enable, PAD type will decide to be up or down, not related with this value<br/>1'b1: pull up/down disable<br/>bit0 - GPIO0C[0] pull up/down control<br/>bit1 - GPIO0C[1] pull up/down control<br/>bit2 - GPIO0C[2] pull up/down control<br/>...<br/>bit7 - GPIO0C[7] pull up/down control</p>   |

**GRF\_GPIO1L\_PULL**

Address: Operational Base + offset (0x0120)

GPIO1A/GPIO1B pull up/down control

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

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:8 | RW   | 0x00        | <p>gpio1b_pull<br/>GPIO1B pull up/down enable<br/>Values written to this register independently control Pullup/Pulldown or not for the corresponding data bit in GPIO.<br/>1'b0: pull up/down enable, PAD type will decide to be up or down, not related with this value<br/>1'b1: pull up/down disable<br/>bit8 - GPIO1B[0] pull up/down control<br/>bit9 - GPIO1B[1] pull up/down control<br/>bit10 - GPIO1B[2] pull up/down control<br/>...<br/>bit15 - GPIO1B[7] pull up/down control</p> |
| 7:0  | RW   | 0x00        | <p>gpio1a_pull<br/>GPIO1A pull up/down enable<br/>Values written to this register independently control Pullup/Pulldown or not for the corresponding data bit in GPIO.<br/>1'b0: pull up/down enable, PAD type will decide to be up or down, not related with this value<br/>1'b1: pull up/down disable<br/>bit0 - GPIO1A[0] pull up/down control<br/>bit1 - GPIO1A[1] pull up/down control<br/>bit2 - GPIO1A[2] pull up/down control<br/>...<br/>bit7 - GPIO1A[7] pull up/down control</p>   |

**GRF\_GPIO1H\_PULL**

Address: Operational Base + offset (0x0124)

GPIO1C(GPIO1D) pull up/down control

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

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:8 | RW   | 0x00        | <p>gpio1d_pull<br/>GPIO1d pull up/down enable<br/>Values written to this register independently control Pullup/Pulldown or not for the corresponding data bit in GPIO.<br/>1'b0: pull up/down enable, PAD type will decide to be up or down, not related with this value<br/>1'b1: pull up/down disable<br/>bit8 - GPIO1D[0] pull up/down control<br/>bit9 - GPIO1D[1] pull up/down control<br/>bit10 - GPIO1D[2] pull up/down control<br/>...<br/>bit15 - GPIO1D[7] pull up/down control</p> |
| 7:0  | RW   | 0x00        | <p>gpio1c_pull<br/>GPIO1C pull up/down enable<br/>Values written to this register independently control Pullup/Pulldown or not for the corresponding data bit in GPIO.<br/>1'b0: pull up/down enable, PAD type will decide to be up or down, not related with this value<br/>1'b1: pull up/down disable<br/>bit0 - GPIO1C[0] pull up/down control<br/>bit1 - GPIO1C[1] pull up/down control<br/>bit2 - GPIO1C[2] pull up/down control<br/>...<br/>bit7 - GPIO1C[7] pull up/down control</p>   |

**GRF\_GPIO2L\_PULL**

Address: Operational Base + offset (0x0128)

GPIO2A/GPIO2B pull up/down control

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

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:8 | RW   | 0x00        | <p>gpio2b_pull<br/>GPIO2B pull up/down enable<br/>Values written to this register independently control Pullup/Pulldown or not for the corresponding data bit in GPIO.<br/>1'b0: pull up/down enable, PAD type will decide to be up or down, not related with this value<br/>1'b1: pull up/down disable<br/>bit8 - GPIO2B[0] pull up/down control<br/>bit9 - GPIO2B[1] pull up/down control<br/>bit10 - GPIO2B[2] pull up/down control<br/>...<br/>bit15 - GPIO2B[7] pull up/down control</p> |
| 7:0  | RW   | 0x00        | <p>gpio2a_pull<br/>GPIO2A pull up/down enable<br/>Values written to this register independently control Pullup/Pulldown or not for the corresponding data bit in GPIO.<br/>1'b0: pull up/down enable, PAD type will decide to be up or down, not related with this value<br/>1'b1: pull up/down disable<br/>bit0 - GPIO2A[0] pull up/down control<br/>bit1 - GPIO2A[1] pull up/down control<br/>bit2 - GPIO2A[2] pull up/down control<br/>...<br/>bit7 - GPIO2A[7] pull up/down control</p>   |

**GRF\_GPIO2H\_PULL**

Address: Operational Base + offset (0x012c)

GPIO2C/GPIO2D pull up/down control

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

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:8 | RW   | 0x00        | <p>gpio2d_pull<br/>GPIO2d pull up/down enable<br/>Values written to this register independently control Pullup/Pulldown or not for the corresponding data bit in GPIO.<br/>1'b0: pull up/down enable, PAD type will decide to be up or down, not related with this value<br/>1'b1: pull up/down disable<br/>bit8 - GPIO2D[0] pull up/down control<br/>bit9 - GPIO2D[1] pull up/down control<br/>bit10 - GPIO2D[2] pull up/down control<br/>...<br/>bit15 - GPIO2D[7] pull up/down control</p> |
| 7:0  | RW   | 0x00        | <p>gpio2c_pull<br/>GPIO2C pull up/down enable<br/>Values written to this register independently control Pullup/Pulldown or not for the corresponding data bit in GPIO.<br/>1'b0: pull up/down enable, PAD type will decide to be up or down, not related with this value<br/>1'b1: pull up/down disable<br/>bit0 - GPIO2C[0] pull up/down control<br/>bit1 - GPIO2C[1] pull up/down control<br/>bit2 - GPIO2C[2] pull up/down control<br/>...<br/>bit7 - GPIO2C[7] pull up/down control</p>   |

**GRF\_SOC\_CON0**

Address: Operational Base + offset (0x0140)

SoC control register 0

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                          |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | <p>write_enable<br/>bit 0~bit 15 write enable<br/>When bit 16=1, bit 0 can be written by software;<br/>When bit 16=0, bit 0 cannot be written by software;<br/>When bit 17=1, bit 1 can be written by software;<br/>When bit 17=0, bit 1 cannot be written by software;<br/>.....<br/>When bit 31=1, bit 15 can be written by software;<br/>When bit 31=0, bit 15 cannot be written by software.</p> |
| 15    | RW   | 0x0         | <p>emac_newrcv_en<br/>the selection of RMII receive selection<br/>1'b0: don't support the data package without header<br/>1'b1: support the data package without header</p>                                                                                                                                                                                                                          |
| 14    | RW   | 0x0         | <p>ddr_8bit_en<br/>When 8bit ddr is used, this bit should be 1.</p>                                                                                                                                                                                                                                                                                                                                  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| 13         | RW          | 0x0                | msch4_mainpartialpop<br>1'b0: 16bit ddr<br>1'b1: 8bit ddr                                                                                       |
| 12         | RW          | 0x0                | soc_remap<br>remap bit control<br>When soc_remap = 1, the bootrom is mapped to address 0x10100000 and internal memory is mapped to address 0x0. |
| 11         | RW          | 0x1                | grf_force_jtag<br>Force select jtag function from sdmmc0 IO, High valid.                                                                        |
| 10         | RW          | 0x0                | acodec_sel<br>1'b0: i2s_sdi from gpio is selected<br>1'b1: i2s_sdi from acodec is selected                                                      |
| 9          | RW          | 0x0                | emac_speed<br>1'b0: 10MHz<br>1'b1: 100MHz                                                                                                       |
| 8          | RW          | 0x0                | emac_mode<br>1'b0: rmii<br>1'b1: mii                                                                                                            |
| 7          | RW          | 0x0                | mobile_ddr_sel<br>This bit is used to tell ddr monitor the type of ddr used.<br>1'b0: DDR3/DDR3L<br>1'b1: not used                              |
| 6          | RW          | 0x0                | dfi_eff_stat_en<br>dfi monitor start to work.<br>1'b1: dfi monitor works.<br>1'b0: dfi monitor stops.                                           |
| 5:4        | RW          | 0x2                | sd_detectn_debounce_sel<br>sd_detectn debounce time select<br>2'b00: 5ms<br>2'b01: 15ms<br>2'b10: 35ms<br>2'b11: 50ms                           |
| 3          | RW          | 0x0                | sd_detectn_fall_int_en<br>SD detectn negedge interrupt enable<br>1'b0: interrupt disable<br>1'b1: interrupt enable                              |
| 2          | RW          | 0x0                | sd_detectn_rise_int_en<br>SD detectn posedge interrupt enable<br>1'b0: interrupt disable<br>1'b1: interrupt enable                              |
| 1          | RW          | 0x0                | sd_detectn_fall_int_pd<br>SD detectn negedge interrupt pending bit<br>wirte 1 to it, it will be cleared.                                        |

| Bit | Attr | Reset Value | Description                                                                                              |
|-----|------|-------------|----------------------------------------------------------------------------------------------------------|
| 0   | RW   | 0x0         | sd_detectn_rise_int_pd<br>SD detectn posedge interrupt pending bit<br>wirte 1 to it, it will be cleared. |

**GRF\_SOC\_CON1**

Address: Operational Base + offset (0x0144)

SoC control register 1

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                           |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>bit 0~bit 15 write enable<br>When bit 16=1, bit 0 can be written by software;<br>When bit 16=0, bit 0 cannot be written by software;<br>When bit 17=1, bit 1 can be written by software;<br>When bit 17=0, bit 1 cannot be written by software;<br>.....<br>When bit 31=1, bit 15 can be written by software;<br>When bit 31=0, bit 15 cannot be written by software. |
| 15:9  | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                              |
| 8     | RW   | 0x0         | peri_usb_pause<br>peri usb ahb bus arbiter pause control<br>USB AHB bus arbiter pause control<br>1'b1: pause<br>1'b0: work                                                                                                                                                                                                                                                            |
| 7     | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                              |
| 6     | RW   | 0x0         | i2s_lrck_sel<br>1'b0: seperate tx_lrck/rx_lrck signal;<br>1'b1: mux tx_lrck/rx_lrck signal                                                                                                                                                                                                                                                                                            |
| 5     | RW   | 0x0         | pwm_sel<br>Select pwm_0 iomux<br>1'b0: pwm_0(gpio0d2)<br>1'b1: pwm1_0(gpio1a2)                                                                                                                                                                                                                                                                                                        |
| 4     | RW   | 0x0         | i2s_sel<br>1'b0: i2s0<br>1'b1: i2s1                                                                                                                                                                                                                                                                                                                                                   |
| 3     | RW   | 0x0         | hevclite_vcodec_sel<br>1'b0: vpu<br>1'b1: hevc                                                                                                                                                                                                                                                                                                                                        |
| 2:0   | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                              |

**GRF\_SOC\_CON2**

Address: Operational Base + offset (0x0148)

SoC control register 2

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | <p>write_enable<br/>bit0~bit15 write enable<br/>When bit 16=1, bit 0 can be written by software;<br/>When bit 16=0, bit 0 cannot be written by software;<br/>When bit 17=1, bit 1 can be written by software;<br/>When bit 17=0, bit 1 cannot be written by software;<br/>.....<br/>When bit 31=1, bit 15 can be written by software;<br/>When bit 31=0, bit 15 cannot be written by software.</p> |
| 15         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                           |
| 14         | RW          | 0x0                | <p>msch_pwr_idlereq<br/>NOC memory scheduler idle request, high valid.</p>                                                                                                                                                                                                                                                                                                                         |
| 13         | RW          | 0x0                | <p>core_pwr_idlereq<br/>NOC pd_core idle request, high valid.</p>                                                                                                                                                                                                                                                                                                                                  |
| 12         | RW          | 0x0                | <p>peri_pwr_idlereq<br/>NOC pd_peri idle request, high valid.</p>                                                                                                                                                                                                                                                                                                                                  |
| 11         | RW          | 0x0                | <p>vio_pwr_idlereq<br/>NOC pd_vio idle request, high valid.</p>                                                                                                                                                                                                                                                                                                                                    |
| 10         | RW          | 0x0                | <p>vpu_pwr_idlereq<br/>NOC pd_video idle request, high valid.</p>                                                                                                                                                                                                                                                                                                                                  |
| 9          | RW          | 0x0                | <p>gpu_pwr_idlereq<br/>NOC pd_gpu idle request, high valid.</p>                                                                                                                                                                                                                                                                                                                                    |
| 8          | RW          | 0x0                | <p>sys_pwr_idlereq<br/>NOC pd_cpu domain idle request, high valid.</p>                                                                                                                                                                                                                                                                                                                             |
| 7          | RW          | 0x1                | <p>msch4_mainaddr3<br/>When DDR3 is used, software should configure this bit to 1.</p>                                                                                                                                                                                                                                                                                                             |
| 6          | RW          | 0x0                | <p>vop_hdmi_den_pol<br/>HDMI den polarity<br/>1'b1: low active<br/>1'b0: high active</p>                                                                                                                                                                                                                                                                                                           |
| 5          | RW          | 0x0                | <p>vop_hdmi_vsync_pol<br/>HDMI vsync polarity<br/>1'b1: low active<br/>1'b0: high active</p>                                                                                                                                                                                                                                                                                                       |
| 4          | RW          | 0x0                | <p>vop_hdmi_hsync_pol<br/>HDMI hsync polarity<br/>1'b1: low active<br/>1'b0: high active</p>                                                                                                                                                                                                                                                                                                       |
| 3:2        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                           |
| 1          | RW          | 0x1                | <p>upctl_c_sysreq<br/>software configure enter DDR self-refresh by lowpower interface<br/>System low-power request. Low active.</p>                                                                                                                                                                                                                                                                |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0          | RW          | 0x0                | <p>upctl_c_active_in<br/>DDR clock active in. External signal from system that flags if a hardware low power request can be accepted or should always be denied.</p> <p>1'b0: may be accepted<br/>1'b1: will be denied</p> |

**GRF\_SOC\_STATUS0**

Address: Operational Base + offset (0x014c)

SoC status register 0

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                             |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------|
| 31         | RO          | 0x0                | reserved                                                                                       |
| 30         | RW          | 0x0                | <p>msch_pwr_idle<br/>NOC memory scheduler idle state. "1" indicates idle.</p>                  |
| 29         | RO          | 0x0                | <p>sys_pwr_idle<br/>NOC pd_cpu idle state. "1" indicates idle.</p>                             |
| 28         | RO          | 0x0                | <p>gpu_pwr_idle<br/>NOC pd_gpu idle state. "1" indicates idle.</p>                             |
| 27         | RO          | 0x0                | <p>vpu_pwr_idle<br/>NOC pd_vpu idle state. "1" indicates idle.</p>                             |
| 26         | RO          | 0x0                | <p>vio_pwr_idle<br/>NOC pd_vio idle state. "1" indicates idle.</p>                             |
| 25         | RO          | 0x0                | <p>peri_pwr_idle<br/>NOC pd_peri idle state. "1" indicates idle.</p>                           |
| 24         | RO          | 0x0                | <p>core_pwr_idle<br/>NOC pd_core idle state. "1" indicates idle.</p>                           |
| 23         | RW          | 0x0                | <p>msch_pwr_idleack<br/>NOC memory scheduler idle acknowledge. high valid.</p>                 |
| 22         | RO          | 0x0                | <p>sys_pwr_idleack<br/>NOC pd_cpu idle acknowledge. high valid.</p>                            |
| 21         | RO          | 0x0                | <p>gpu_pwr_idleack<br/>NOC pd_gpu idle acknowledge. high valid.</p>                            |
| 20         | RO          | 0x0                | <p>vpu_pwr_idleack<br/>NOC pd_vpu idle acknowledge. high valid.</p>                            |
| 19         | RO          | 0x0                | <p>vio_pwr_idleack<br/>NOC pd_vio idle acknowledge. high valid.</p>                            |
| 18         | RO          | 0x0                | <p>peri_pwr_idleack<br/>NOC pd_peri idle acknowledge. high valid.</p>                          |
| 17         | RO          | 0x0                | <p>core_pwr_idleack<br/>NOC pd_core idle acknowledge. high valid.</p>                          |
| 16         | RO          | 0x0                | <p>host20_iddig<br/>Host 2.0 iddig status<br/>Host 2.0 iddig state. It will always be "0".</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:14      | RO          | 0x0                | <p>host20_linestate<br/>Host 2.0 linestate status<br/>This bus reflects the state of the single-ended receivers. In Suspend or Sleep mode, this bus is a combinatorial output (directly reflecting the current state of D- and D+, respectively).</p> <p>2'b11: SE1 (D+ high, D- high)<br/>2'b10: K state for high-speed and full-speed USB traffic; J state for low-speed USB traffic (D+ low, D- high)<br/>2'b01: J state for high-speed and full-speed USB traffic; K state for low-speed USB traffic (D+ high, D- low)<br/>2'b00: SE0 (D+ low, D- low)</p> <p>During normal high-speed packet transfers, the line indicates a high-speed J state.</p> |
| 13         | RO          | 0x0                | <p>host20_bvalid<br/>Host 2.0 bvalid status<br/>B-Device Session Valid Indicator<br/>Function: This controller signal is output from the USB 2.0 Session Valid comparator and indicates whether the session for a B-device is valid.</p> <p>1'b1: The session for the B-device is valid.<br/>1'b0: The session for the B-device is not valid.</p>                                                                                                                                                                                                                                                                                                         |
| 12         | RO          | 0x0                | <p>host20_vbusvalid<br/>Host 2.0 vbus valid status<br/>VBUS Valid Indicator<br/>Function: This controller signal is output from the USB 2.0 VBUS Valid comparator and indicates whether the VBUS output is at a valid level.</p> <p>1'b1: The VBUS output is valid.<br/>1'b0: The VBUS output is not valid.</p>                                                                                                                                                                                                                                                                                                                                           |
| 11         | RO          | 0x1                | <p>otg0_iddig<br/>otg0 iddig status<br/>1'b0: indicate otg work as host<br/>1'b1: indicate otg work as device</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 10:9       | RO          | 0x0                | <p>otg0_linestate<br/>otg0 linestate status<br/>This bus reflects the state of the single-ended receivers. In Suspend or Sleep mode, this bus is a combinatorial output (directly reflecting the current state of D- and D+, respectively).</p> <p>2'b11: SE1 (D+ high, D- high)<br/>2'b10: K state for high-speed and full-speed USB traffic; J state for low-speed USB traffic (D+ low, D- high)<br/>2'b01: J state for high-speed and full-speed USB traffic; K state for low-speed USB traffic (D+ high, D- low)<br/>2'b00: SE0 (D+ low, D- low)</p> <p>During normal high-speed packet transfers, the line indicates a high-speed J state.</p>       |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                  |
|-----|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8   | RO   | 0x0         | otg0_bvalid<br>otg0 bvalid status<br>B-Device Session Valid Indicator<br>Function: This controller signal is output from the USB 2.0 Session Valid comparator and indicates whether the session for a B-device is valid.<br>1'b1: The session for the B-device is valid.<br>1'b0: The session for the B-device is not valid. |
| 7   | RO   | 0x0         | otg0_vbusvalid<br>otg0 vbus valid status<br>VBUS Valid Indicator<br>Function: This controller signal is output from the USB 2.0 VBUS Valid comparator and indicates whether the VBUS output is at a valid level.<br>1'b1: The VBUS output is valid.<br>1'b0: The VBUS output is not valid.                                   |
| 6:4 | RO   | 0x0         | pll_lock<br>Pll lock status:<br>bit2: generalpll_lock<br>bit1: armpll_lock<br>bit0: ddrpll_lock<br>1'b1: pll is lock<br>1'b0: pll is unlock                                                                                                                                                                                  |
| 3:0 | RO   | 0x0         | timer_en_status<br>bit0: timer 0 enable status<br>bit1: timer 1 enable status<br>bit2: timer 2 enable status<br>bit3: timer 3 enable status<br>High active                                                                                                                                                                   |

**GRF\_SOC\_CON3**

Address: Operational Base + offset (0x0154)

SoC control register 3

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12:7       | RW          | 0x3f               | cvbsdac_gain_grf<br>Gain setting digital input word for channel 0                                                                                                                                                                                  |
| 6:4        | RW          | 0x0                | cvbsdac_enctr_grf<br>Enable control pins for analog biasing Test. In normal mode set enctr[2..0]=000                                                                                                                                               |
| 3          | RW          | 0x0                | cvbsdac_ensc0_grf<br>Sense comparator enable for cable connection detection of DAC0                                                                                                                                                                |
| 2          | RW          | 0x1                | cvbsdac_endac0_grf<br>Enable control pin to power up theDAC0                                                                                                                                                                                       |
| 1          | RW          | 0x1                | cvbsdac_envbg_grf<br>Enable control pin to power up internal bandgap.<br>1'b1: Internal bandgap is ON;<br>1'b0: Internal bandgap is OFF.                                                                                                           |
| 0          | RW          | 0x0                | cvbsdac_enextref_grf<br>Enable control pin to allow internally generated bandgap to be probed in the analog pin 'vbg'. Under normal operation and envbg=1:<br>1'b1: Internal bandgap is passed to vbg pin;<br>1'b0: vbg pins is at high impedance. |

**GRF\_UOC0\_CON5**

Address: Operational Base + offset (0x017c)

OTG control register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>bit 0 ~ bit 15 write enable<br>When bit 16=1, bit 0 can be written by software;<br>When bit 16=0, bit 0 cannot be written by software;<br>When bit 17=1, bit 1 can be written by software;<br>When bit 17=0, bit 1 cannot be written by software;<br>.....<br>When bit 31=1, bit 15 can be written by software;<br>When bit 31=0, bit 15 cannot be written by software. |
| 15         | RW          | 0x0                | otg0_bvalid_irq_pd<br>otg0 bvalid interrupt pending bit<br>write 1 to this bit, it will be cleared.                                                                                                                                                                                                                                                                                     |
| 14         | RW          | 0x0                | otg0_bvalid_irq_en<br>otg0 bvalid interrupt enable<br>1'b1: interrupt enable<br>1'b0: interrupt disable                                                                                                                                                                                                                                                                                 |
| 13         | RW          | 0x0                | otg0_linestate_irq_pd<br>otg0 linestate interrupt pending<br>write 1 to this bit, it will be cleared.                                                                                                                                                                                                                                                                                   |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12         | RW          | 0x0                | otg0_linestate_irq_en<br>otg0 linestate change interrupt enable<br>1'b1: interrupt enable<br>1'b0: interrupt disable                                                                                                                                                                                                                                                                                                                                                                                  |
| 11         | RW          | 0x0                | otg0_usbphy_commonon<br>OTG0 Common Block Power-Down Control<br>This signal controls the power-down signals in the XO, Bias, and PLL blocks when the USB 2.0 PHY is in Suspend or Sleep mode<br>1'b1: In Suspend mode, the XO, Bias, and PLL blocks are powered down. In Sleep mode, the Bias and PLL blocks are powered down<br>1'b0: In Suspend mode, the XO, Bias, and PLL blocks remain powered in Suspend mode. In Sleep mode, if the reference clock is a crystal, the XO block remains powered |
| 10         | RW          | 0x0                | otg0_iddig_status<br>OTG0 control software iddig value<br>1'b0: host<br>1'b1: device                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 9          | RW          | 0x0                | otg0_iddig_sft_sel<br>1'b0: iddig to otg controller select usbphy output<br>1'b1: iddig to otg controller select grf_uoc0_con5[10]                                                                                                                                                                                                                                                                                                                                                                    |
| 8          | RW          | 0x0                | otg0_utmi_dmpulldown<br>1'b0: DM 15 KOhm pull down disabled<br>1'b1: DM 15 KOhm pull down enable                                                                                                                                                                                                                                                                                                                                                                                                      |
| 7          | RW          | 0x0                | otg0_utmi_dppulldown<br>1'b0: DP 15 KOhm pull down disabled<br>1'b1: DP 15 KOhm pull down enable                                                                                                                                                                                                                                                                                                                                                                                                      |
| 6          | RW          | 0x0                | otg0_utmi_termselect<br>OTG0 USB Termination Select<br>1'b1: Full-speed terminations are enabled.<br>1'b0: High-speed terminations are enabled.                                                                                                                                                                                                                                                                                                                                                       |
| 5:4        | RW          | 0x0                | otg0_utmi_xcvrselect<br>OTG0 Transceiver Select<br>2'b11: Sends an LS packet on an FS bus or receives an LS packet.<br>2'b10: LS Transceiver<br>2'b01: FS Transceiver<br>2'b00: HS Transceiver                                                                                                                                                                                                                                                                                                        |
| 3:2        | RW          | 0x0                | otg0_utmi_opmode<br>OTG0 UTMI+ Operational Mode<br>Function: This controller bus selects the UTMI+ operational mode.<br>2'b11: Normal operation without SYNC or EOP generation. If the XCVRSEL bus is not set to 00 while OPMODE[1:0] is set to 11, USB PHY behavior is undefined.<br>2'b10: Disable bit stuffing and NRZI encoding<br>2'b01: Non-Driving<br>2'b00: Normal                                                                                                                            |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                       |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------|
| 1          | RW          | 0x0                | otg0_utmi_suspend_n<br>OTG0 Suspend Assertion<br>1'b1: Normal operating mode<br>1'b0: Suspend mode       |
| 0          | RW          | 0x0                | otg0_phy_soft_con_sel<br>1'b0: software control usb phy disable<br>1'b1: software control usb phy enable |

**GRF\_UOC1\_CON4**

Address: Operational Base + offset (0x0190)

USB HOST 2.0 control register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_enable<br>bit0~bit15 write enable<br>When bit 16=1, bit 0 can be written by software;<br>When bit 16=0, bit 0 cannot be written by software;<br>When bit 17=1, bit 1 can be written by software;<br>When bit 17=0, bit 1 cannot be written by software;<br>.....<br>When bit 31=1, bit 15 can be written by software;<br>When bit 31=0, bit 15 cannot be written by software.                                                                             |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 13         | RW          | 0x0                | bypasssel0<br>Transmitter Digital Bypass mode Enable. When 1, otg used as a UART2 port.                                                                                                                                                                                                                                                                                                                                                                         |
| 12         | RW          | 0x0                | bypassdmen0<br>DM0 Transmitter Digital Bypass Enable. high valid.                                                                                                                                                                                                                                                                                                                                                                                               |
| 11         | RW          | 0x0                | host20_phydisable<br>when 1, host 2.0 phy disable                                                                                                                                                                                                                                                                                                                                                                                                               |
| 10         | RW          | 0x0                | otg0_phydisable<br>when 1, otgphy is disabled.                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 9:8        | RW          | 0x0                | otg0_scaledown<br>Scale-Down Mode<br>2'b00: Disables all scale-downs. Actual timing values are used.<br>Required for synthesis.<br>2'b01: Enables scale-down of all timing values except Device mode suspend and resume. These include:<br>- Speed enumeration.<br>- HNP/SRP.<br>- Host mode suspend and resume.<br>2'b10: Enables scale-down of Device mode suspend and resume timing values only.<br>2'b11: Enables bit 0 and bit 1 scale-down timing values. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:6        | RW          | 0x0                | <p>host20_scaledown<br/>Host20 Scale-Down Mode<br/>2'b00: Disables all scale-downs. Actual timing values are used.<br/>Required for synthesis.</p> <p>2'b01: Enables scale-down of all timing values except Device mode suspend and resume. These include:</p> <ul style="list-style-type: none"> <li>- Speed enumeration.</li> <li>- HNP/SRP.</li> <li>- Host mode suspend and resume.</li> </ul> <p>2'b10: Enables scale-down of Device mode suspend and resume timing values only.</p> <p>2'b11: Enables bit 0 and bit 1 scale-down timing values.</p> |
| 5          | RW          | 0x0                | <p>host20_utmiotg_idpullup<br/>Host20 Analog ID Input Sample Enable<br/>Function: This controller signal controls ID line sampling.</p> <p>1'b1: ID pin sampling is enabled, and the IDDIG output is valid.</p> <p>1'b0: ID pin sampling is disabled, and the IDDIG output is not valid.</p>                                                                                                                                                                                                                                                              |
| 4          | RW          | 0x1                | <p>host20_utmiotg_dppulldown<br/>Host20 D+ Pull-Down Resistor Enable</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 3          | RW          | 0x1                | <p>host20_utmiotg_dmpulldown<br/>Host20 D- Pull-Down Resistor Enable</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 2          | RW          | 0x1                | <p>host20_utmiotg_drvvbus<br/>Host20 Drive VBUS</p> <p>1'b1: The VBUS Valid comparator is enabled.</p> <p>1'b0: The VBUS Valid comparator is disabled.</p>                                                                                                                                                                                                                                                                                                                                                                                                |
| 1          | RW          | 0x0                | <p>host20_utmisrp_chrgvbus<br/>Host20 VBUS Input Charge Enable</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 0          | RW          | 0x0                | <p>host20_utmisrp_dischrgvbus<br/>Host20 VBUS Input Discharge Enable</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

**GRF\_UOC1\_CON5**

Address: Operational Base + offset (0x0194)

USB HOST 2.0 control register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | <p>write_enable<br/>bit 0 ~ bit 15 write enable</p> <p>When bit 16=1, bit 0 can be written by software;</p> <p>When bit 16=0, bit 0 cannot be written by software;</p> <p>When bit 17=1, bit 1 can be written by software;</p> <p>When bit 17=0, bit 1 cannot be written by software;</p> <p>.....</p> <p>When bit 31=1, bit 15 can be written by software;</p> <p>When bit 31=0, bit 15 cannot be written by software.</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15         | RW          | 0x0                | host20_linestate_irq_pd<br>Host2.0 linestate interrupt pending<br>write 1 to this bit, it will be cleared.                                                                                                                                                                                                                                                                      |
| 14         | RW          | 0x0                | host20_linestate_irq_en<br>Host2.0 linestate interrupt enable                                                                                                                                                                                                                                                                                                                   |
| 13:9       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                        |
| 8          | RW          | 0x0                | host20_utmi_dmpulldown<br>1'b0: DM 15 KOhm pull down disabled<br>1'b1: DM 15 KOhm pull down enable                                                                                                                                                                                                                                                                              |
| 7          | RW          | 0x0                | host20_utmi_dppulldown<br>1'b0: DP 15 KOhm pull down disabled<br>1'b1: DP 15 KOhm pull down enable                                                                                                                                                                                                                                                                              |
| 6          | RW          | 0x0                | host20_utmi_termselect<br>Host2.0 USB Termination Select<br>1'b1: Full-speed terminations are enabled<br>1'b0: High-speed terminations are enabled                                                                                                                                                                                                                              |
| 5:4        | RW          | 0x0                | host20_utmi_xcvrselect<br>Host2.0 Transceiver Select<br>2'b11: Sends an LS packet on an FS bus or receives an LS packet.<br>2'b10: LS Transceiver<br>2'b01: FS Transceiver<br>2'b00: HS Transceiver                                                                                                                                                                             |
| 3:2        | RW          | 0x0                | host20_utmi_opmode<br>Host2.0 UTMI+ Operational Mode<br>Function: This controller bus selects the UTMI+ operational mode.<br>2'b11: Normal operation without SYNC or EOP generation. If the XCVRSEL bus is not set to 00 while OPMODE[1:0] is set to 11, USB PHY behavior is undefined.<br>2'b10: Disable bit stuffing and NRZI encoding<br>2'b01: Non-Driving<br>2'b00: Normal |
| 1          | RW          | 0x0                | host20_utmi_suspend_n<br>Host2.0 Suspend Assertion<br>1'b1: Normal operating mode<br>1'b0: Suspend mode                                                                                                                                                                                                                                                                         |
| 0          | RW          | 0x0                | host20_phy_soft_con_sel<br>1'b0: software control usb phy disable<br>1'b1: software control usb phy enable                                                                                                                                                                                                                                                                      |

**GRF\_DDRC\_STAT**

Address: Operational Base + offset (0x019c)

DDRC status register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>         |
|------------|-------------|--------------------|----------------------------|
| 31:21      | RW          | 0x000              | gpu_idle<br>gpu idle staus |

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                         |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 20    | RW   | 0x1         | ddrupctl_c_active<br>confirm that system external to PCTL can accept a Low-power request. low valid.                                                                                                                                                                                |
| 19    | RW   | 0x1         | ddrupctl_c_sysack<br>PCTL low-power request status response. low valid.                                                                                                                                                                                                             |
| 18:16 | RO   | 0x0         | ddrupctl_stat<br>Current state of the protocol controller<br>3'b000: Init_mem<br>3'b001: Config<br>3'b010: Config_req<br>3'b011: Access<br>3'b100: Access_req<br>3'b101: Low_power<br>3'b110: Low_power_entry_req<br>3'b111: Low_power_exit_req                                     |
| 15:0  | RO   | 0x0000      | ddrupctl_bbflags<br>Bank busy indication<br>NIF output vector which provides combined information about the status of each memory bank. The de-assertion is based on when precharge, activates, reads/writes.<br>Bit0 indication Bank0 busy, bit1 indication Bank1 busy, and so on. |

**GRF\_UOC\_CON6**

Address: Operational Base + offset (0x01a0)

USB control register

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                             |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>bit 0 ~ bit 15 write enable<br>When bit 16=1, bit 0 can be written by software;<br>When bit 16=0, bit 0 cannot be written by software;<br>When bit 17=1, bit 1 can be written by software;<br>When bit 17=0, bit 1 cannot be written by software;<br>.....<br>When bit 31=1, bit 15 can be written by software;<br>When bit 31=0, bit 15 cannot be written by software. |
| 15    | RO   | 0x0         | otg0_bvalid_f<br>otg0 vbus bvalid status after filter<br>B-Device Session Valid Indicator<br>Function: This controller signal is output from the USB 2.0 Session Valid comparator and indicates whether the session for a B-device is valid.<br>1'b1: The session for the B-device is valid.<br>1'b0: The session for the B-device is not valid.                                        |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------|
| 14         | RO          | 0x1                | otg0_iddig_f<br>otg0 iddig status after filter<br>1'b0: otg works as a host<br>1'b1: otg works as a device.                      |
| 13:10      | RO          | 0x0                | reserved                                                                                                                         |
| 9:8        | RW          | 0x2                | host20_linestate_filter_sel<br>Host2.0 linestate filter time select<br>2'b00: 100us<br>2'b01: 500us<br>2'b10: 1ms<br>2'b11: 10ms |
| 7:6        | RW          | 0x2                | otg0_linestate_filter_sel<br>otg0 linestate filter time select<br>2'b00: 100us<br>2'b01: 500us<br>2'b10: 1ms<br>2'b11: 10ms      |
| 5:4        | RW          | 0x2                | otg0_id_filter_sel<br>otg0 iddig filter time select<br>2'b00: 5ms<br>2'b01: 15ms<br>2'b10: 35ms<br>2'b11: 50ms                   |
| 3          | RW          | 0x0                | otg0_id_fall_irq_pd<br>otg0 id negedge interrupt pending<br>write 1 to this bit, it will be cleared.                             |
| 2          | RO          | 0x0                | otg0_id_fall_irq_en<br>otg0 id negedge interrupt enable<br>1'b1 : interrupt enable<br>1'b0 : interrupt disable                   |
| 1          | RW          | 0x0                | otg0_id_rise_irq_pd<br>otg0 id posedge interrupt pending<br>write 1 to this bit, it will be cleared.                             |
| 0          | RW          | 0x0                | otg0_id_rise_irq_en<br>otg0 id posedge interrupt enable<br>1'b1: interrupt enable<br>1'b0: interrupt disable                     |

**GRF\_SOC\_STATUS1**

Address: Operational Base + offset (0x01a4)

SoC status register 1

| <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          | RW          | 0x0                | vdac_enctr3_grf<br>Enable control pins for analog biasing Test. In normal mode set enctr[2..0]=000                                                                       |
| 0          | RW          | 0x0                | vdac_cableout0_grf<br>CVBS DAC cable out flag to indicate that the cable of the DAC is unplugged.<br>cableoutx=1 indicates that the DAC is not connected to the outside. |

**GRF\_CPU\_CON0**

Address: Operational Base + offset (0x01a8)

CPU control register 0

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>bit0 ~ bit15 write enable<br>When bit 16=1, bit 0 can be written by software;<br>When bit 16=0, bit 0 cannot be written by software;<br>When bit 17=1, bit 1 can be written by software;<br>When bit 17=0, bit 1 cannot be written by software;<br>.....<br>When bit 31=1, bit 15 can be written by software;<br>When bit 31=0, bit 15 cannot be written by software. |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                              |
| 13         | RW          | 0x1                | deviceen_dap<br>Enabling access to the connected debug device or memory system<br>1'b0: disable<br>1'b1: enable                                                                                                                                                                                                                                                                       |
| 12         | RW          | 0x0                | I2rstdisable<br>A7 I2rstdisable bit control                                                                                                                                                                                                                                                                                                                                           |
| 11:10      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                              |
| 9:8        | RW          | 0x0                | I1rstdisable<br>A7 I1rstdisable bit control<br>Every bit for one core, bit1 is for core1, bit0 is for core0.                                                                                                                                                                                                                                                                          |
| 7:3        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                              |
| 2:0        | RW          | 0x2                | ema_l2_data<br>A7 L2 memory EMA control                                                                                                                                                                                                                                                                                                                                               |

**GRF\_CPU\_CON1**

Address: Operational Base + offset (0x01ac)

CPU control register 1

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

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | <p>write_enable</p> <p>bit0 ~ bit15 write enable</p> <p>When bit 16=1, bit 0 can be written by software;</p> <p>When bit 16=0, bit 0 cannot be written by software;</p> <p>When bit 17=1, bit 1 can be written by software;</p> <p>When bit 17=0, bit 1 cannot be written by software;</p> <p>.....</p> <p>When bit 31=1, bit 15 can be written by software;</p> <p>When bit 31=0, bit 15 cannot be written by software.</p> |
| 15:10 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 9:8   | RW   | 0x0         | <p>cfgte</p> <p>Controls processor state for exception handling (TE bit) at reset</p>                                                                                                                                                                                                                                                                                                                                        |
| 7:6   | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 5:4   | RW   | 0x0         | <p>vinithi</p> <p>Cortex-A7 vinithi bit control.</p> <p>location of the exception vectors at reset. Sampled during reset.</p> <p>1'b0: 0x0000_0000</p> <p>1'b1: 0xffff_0000</p>                                                                                                                                                                                                                                              |
| 3:2   | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 1:0   | RW   | 0x0         | <p>cfgend</p> <p>One bit for each processor.</p> <p>1'b0: Little-endian</p> <p>1'b1: Big-endian</p>                                                                                                                                                                                                                                                                                                                          |

**GRF\_CPU\_CON2**

Address: Operational Base + offset (0x01b0)

CPU control register 2

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | <p>wirte_enable</p> <p>bit0 ~ bit15 write enable</p> <p>When bit 16=1, bit 0 can be written by software;</p> <p>When bit 16=0, bit 0 cannot be written by software;</p> <p>When bit 17=1, bit 1 can be written by software;</p> <p>When bit 17=0, bit 1 cannot be written by software;</p> <p>.....</p> <p>When bit 31=1, bit 15 can be written by software;</p> <p>When bit 31=0, bit 15 cannot be written by software.</p> |
| 15:9  | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 8     | RW   | 0x0         | <p>cfgsdisable</p> <p>Disables write access to some secure GIC registers</p> <p>When CFGSDISABLE is asserted, the GIC prevents writes to any register locations that control the operating state of an LSPI</p> <p>1'b0: enable</p> <p>1'b1: disable</p>                                                                                                                                                                     |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7          | RW          | 0x0                | evento_clear<br>Event output<br>Evento is active when one SEV instruction is executed.<br>This bit used to clear evento signal.<br>1'b0: un-clear<br>1'b1: clear                                                                            |
| 6          | RW          | 0x0                | eventi<br>Event input for processor wake-up from WFE state<br>This pin must be asserted for at least one CLKIN clock cycle. When this signal is asserted, it acts as a WFE wake-up event to all the processors in the multiprocessor device |
| 5          | RW          | 0x1                | dbgselfaddrv<br>Debug self-address offset valid<br>1'b0: unvalid<br>1'b1: valid                                                                                                                                                             |
| 4          | RW          | 0x1                | dbgromaddrv<br>Debug ROM physical address valid<br>1'b0: unvalid<br>1'b1: valid                                                                                                                                                             |
| 3          | RW          | 0x1                | spniden<br>Secure privileged non-invasive debug enable                                                                                                                                                                                      |
| 2          | RW          | 0x1                | niden<br>Non-invasive debug enable                                                                                                                                                                                                          |
| 1          | RW          | 0x1                | spiden<br>Secure privileged invasive debug enable                                                                                                                                                                                           |
| 0          | RW          | 0x1                | dbgen<br>Debug enable                                                                                                                                                                                                                       |

**GRF\_CPU\_STATUS0**

Address: Operational Base + offset (0x01c0)

CPU status register 0

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x0                | reserved                                                                                                                                                                            |
| 4:3        | RO          | 0x0                | smpnamp<br>Signals AMP or SMP mode for each Cortex-A7 processor.<br>1'b0: Asymmetric.<br>1'b1: Symmetric.                                                                           |
| 2          | RO          | 0x1                | jtagnw_dap<br>coresight jtagnw signal status<br>1'b1: JTAG is selected.<br>1'b0: SWD is selected.                                                                                   |
| 1          | RO          | 0x1                | jtagtop_dap<br>coresight jtagtop signal status<br>"1" means jtag state machine is in one of the top four modes:<br>test-logic-reset, run-test/idle, select-DR-scan, select-IR-scan. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                     |
|------------|-------------|--------------------|--------------------------------------------------------|
| 0          | RO          | 0x0                | evento_rising_edge<br>evento signal rising edge status |

**GRF\_CPU\_STATUS1**

Address: Operational Base + offset (0x01c4)

CPU status register 2

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                        |
|------------|-------------|--------------------|-----------------------------------------------------------|
| 31:7       | RO          | 0x0                | reserved                                                  |
| 6:5        | RW          | 0x0                | standbywfi<br>core WFI status, 2bit corresponding 2 cores |
| 4:3        | RO          | 0x0                | reserved                                                  |
| 2:1        | RW          | 0x0                | standbywfe<br>core WFE status, 2bit corresponding 2 cores |
| 0          | RO          | 0x0                | standbywfil2<br>L2 WFI status                             |

**GRF\_OS\_REG0**

Address: Operational Base + offset (0x01c8)

Software OS register 0

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

**GRF\_OS\_REG1**

Address: Operational Base + offset (0x01cc)

Software OS register 1

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

**GRF\_OS\_REG2**

Address: Operational Base + offset (0x01d0)

Software OS register 2

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

**GRF\_OS\_REG3**

Address: Operational Base + offset (0x01d4)

Software OS register 3

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

**GRF\_OS\_REG4**

Address: Operational Base + offset (0x01d8)

Software OS register 4

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

**GRF\_OS\_REG5**

Address: Operational Base + offset (0x01dc)

Software OS register 5

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

**GRF\_OS\_REG6**

Address: Operational Base + offset (0x01e0)

Software OS register 6

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

**GRF\_OS\_REG7**

Address: Operational Base + offset (0x01e4)

Software OS register 7

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

**GRF\_PVTM\_CON0**

Address: Operational Base + offset (0x0200)

PVTM control register 0

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>bit0~bit15 write enable<br>When bit 16=1, bit 0 can be written by software;<br>When bit 16=0, bit 0 cannot be written by software;<br>When bit 17=1, bit 1 can be written by software;<br>When bit 17=0, bit 1 cannot be written by software;<br>.....<br>When bit 31=1, bit 15 can be written by software;<br>When bit 31=0, bit 15 cannot be written by software. |
| 15:6       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                            |
| 5          | RW          | 0x0                | pvtm_video_osc_en<br>pd_video PVT monitor oscillator enable<br>1'b1: enable<br>1'b0: disable                                                                                                                                                                                                                                                                                        |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------|
| 4          | RW          | 0x0                | pvtm_video_start<br>pd_video PVT monitor start control                                     |
| 3          | RW          | 0x0                | pvtm_gpu_osc_en<br>pd_gpu PVT monitor oscillator enable<br>1'b1: enable<br>1'b0: disable   |
| 2          | RW          | 0x0                | pvtm_gpu_start<br>pd_gpu PVT monitor start control                                         |
| 1          | RW          | 0x0                | pvtm_core_osc_en<br>pd_core PVT monitor oscillator enable<br>1'b1: enable<br>1'b0: disable |
| 0          | RW          | 0x0                | pvtm_core_start<br>pd_core PVT monitor start control                                       |

**GRF\_PVTM\_CON1**

Address: Operational Base + offset (0x0204)

PVTM control register 1

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | pvtm_core_cal_cnt<br>pd_core pvtm calculator counter |

**GRF\_PVTM\_CON2**

Address: Operational Base + offset (0x0208)

PVTM control register 2

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                 |
|------------|-------------|--------------------|----------------------------------------------------|
| 31:0       | RW          | 0x00000000         | pvtm_gpu_cal_cnt<br>pd_gpu pvtm calculator counter |

**GRF\_PVTM\_CON3**

Address: Operational Base + offset (0x020c)

PVTM control register 3

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                     |
|------------|-------------|--------------------|--------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | pvtm_video_cal_cnt<br>pd_video pvtm calculator counter |

**GRF\_PVTM\_STATUS0**

Address: Operational Base + offset (0x0210)

PVTM status register 0

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------|
| 31:3       | RO          | 0x0                | reserved                                                              |
| 2          | RO          | 0x0                | pvtm_video_freq_done<br>pd_video pvtm frequency calculate done status |
| 1          | RO          | 0x0                | pvtm_core_freq_done<br>pd_core pvtm frequency calculate done status   |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------|
| 0          | RO          | 0x0                | pvtm_gpu_freq_done<br>pd_gpu pvtm frequency calculate done status |

**GRF\_PVTM\_STATUS1**

Address: Operational Base + offset (0x0214)

PVTM status register 1

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                 |
|------------|-------------|--------------------|----------------------------------------------------|
| 31:0       | RO          | 0x00000000         | pvtm_core_freq_cnt<br>pd_core pvtm frequency count |

**GRF\_PVTM\_STATUS2**

Address: Operational Base + offset (0x0218)

PVTM status register 2

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                               |
|------------|-------------|--------------------|--------------------------------------------------|
| 31:0       | RO          | 0x00000000         | pvtm_gpu_freq_cnt<br>pd_gpu pvtm frequency count |

**GRF\_PVTM\_STATUS3**

Address: Operational Base + offset (0x021c)

PVTM status register 3

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | pvtm_video_freq_cnt<br>pd_video pvtm frequency count |

**GRF\_DFI\_WRNUM**

Address: Operational Base + offset (0x0220)

DFI write number register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | dfi_eff_wr_num<br>the total number of write operation on DFI interface. |

**GRF\_DFI\_RDNUM**

Address: Operational Base + offset (0x0224)

DFI read number register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | dfi_eff_rd_num<br>the total number of read operation on DFI interface. |

**GRF\_DFI\_ACTNUM**

Address: Operational Base + offset (0x0228)

DFI active number register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | dfi_eff_act_num<br>the total number of active operation on DFI interface. |

**GRF\_DFI\_TIMERVAL**

Address: Operational Base + offset (0x022c)

DFI work time

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                     |
|------------|-------------|--------------------|--------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | dfi_timer_val<br>the total time for DFI monitor works. |

**GRF\_NIF\_FIFO0**

Address: Operational Base + offset (0x0230)

NIF status register 0

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | nif0_fifo0<br>status for msch4 signals. It will not be cleared by system reset.<br>bit 10 ~ bit 0 : msch4_n_acol[10:0]<br>bit 11 ~ bit 13 : msch4_n_abank[2:0]<br>bit 14 ~ bit 29 : msch4_n_arow[15:0]<br>bit 31 ~ bit 30 : msch4_n_arank_sel[1:0] |

**GRF\_NIF\_FIFO1**

Address: Operational Base + offset (0x0234)

NIF status register 1

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | nif0_fifo1<br>status for msch4 signals. It will not be cleared by system reset.<br>bit 10 ~ bit 0 : msch4_n_acol[10:0]<br>bit 11 ~ bit 13 : msch4_n_abank[2:0]<br>bit 14 ~ bit 29 : msch4_n_arow[15:0]<br>bit 31 ~ bit 30 : msch4_n_arank_sel[1:0] |

**GRF\_NIF\_FIFO2**

Address: Operational Base + offset (0x0238)

NIF status register 2

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | nif0_fifo2<br>status for msch4 signals. It will not be cleared by system reset.<br>bit 10 ~ bit 0 : msch4_n_acol[10:0]<br>bit 11 ~ bit 13 : msch4_n_abank[2:0]<br>bit 14 ~ bit 29 : msch4_n_arow[15:0]<br>bit 31 ~ bit 30 : msch4_n_arank_sel[1:0] |

**GRF\_NIF\_FIFO3**

Address: Operational Base + offset (0x023c)

NIF status register 3

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | nif0_fifo3<br>status for msch4 signals. It will not be cleared by system reset.<br>bit 10 ~ bit 0 : msch4_n_acol[10:0]<br>bit 11 ~ bit 13 : msch4_n_abank[2:0]<br>bit 14 ~ bit 29 : msch4_n_arow[15:0]<br>bit 31 ~ bit 30 : msch4_n_arank_sel[1:0] |

**GRF\_USBPHY0\_CON0**

Address: Operational Base + offset (0x0280)

usbphy control register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_enable<br>bit0~bit15 write enable<br>When bit 16=1, bit 0 can be written by software;<br>When bit 16=0, bit 0 cannot be written by software;<br>When bit 17=1, bit 1 can be written by software;<br>When bit 17=0, bit 1 cannot be written by software;<br>.....<br>When bit 31=1, bit 15 can be written by software;<br>When bit 31=0, bit 15 cannot be written by software. |
| 15:13      | RW          | 0x4                | squel_trigger_con<br>bit2 ~ bit0 of squel_trigger_con.<br>4'b0000: 112.5mV<br>4'b1001: 162.5mV<br>4'b1011: 175mV<br>4'b1100: 150mV(default)<br>4'b1110: 125mV                                                                                                                                                                                                                       |
| 12:11      | RW          | 0x0                | non_driving<br>Registers for non-driving state control. non-driving state is controlled by op-mode by default, when bit[11] is configured with "1", user can control non-driving state through bit[12].                                                                                                                                                                             |
| 10:8       | RW          | 0x6                | tx_clk_phase_con<br>USB Tx Clock phase configure, 3'b000 represent the earliest phase, and 3'b111 the latest, single step delay is 256ps                                                                                                                                                                                                                                            |
| 7:5        | RW          | 0x0                | rx_clk_phase_con<br>USB Rx Clock phase configure, 3'b000 represent the earliest phase, and 3'b111 the latest, single step delay is 256ps                                                                                                                                                                                                                                            |
| 4:3        | RW          | 0x3                | fls_eye_height<br>FS/LS eye height configure, 2'b00 represent the largest slew rate, 2'b11 represent the smallest slew rate                                                                                                                                                                                                                                                         |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                              |
|-----|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:0 | RW   | 0x0         | <p>hs_eye_diag_adjust<br/>HS eye diagram adjust, open HS pre-emphasize function to increase HS slew rate, only used when large cap loading is attached.</p> <p>3'b001: open pre-emphasize in sof or eop state<br/>3'b010: open pre-emphasize in chirp state<br/>3'b100: open pre-emphasize in non-chirp state<br/>3'b111: always open pre-emphasize<br/>other combinations: reserved</p> |

**GRF\_USBPHY0\_CON1**

Address: Operational Base + offset (0x0284)

usbphy control register

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                        |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0x0000      | <p>write_enable<br/>bit0~bit15 write enable<br/>When bit 16=1, bit 0 can be written by software;<br/>When bit 16=0, bit 0 cannot be written by software;<br/>When bit 17=1, bit 1 can be written by software;<br/>When bit 17=0, bit 1 cannot be written by software;<br/>.....<br/>When bit 31=1, bit 15 can be written by software;<br/>When bit 31=0, bit 15 cannot be written by software.</p> |
| 15:13 | RW   | 0x7         | <p>hs_eye_height<br/>bit2 ~ bit 0 of hs_eye_height.<br/>HS eye height tuning, more zeros represent bigger eye, more ones represent smaller eye.</p>                                                                                                                                                                                                                                                |
| 12:3  | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                           |
| 2     | RW   | 0x1         | <p>current_comp_en<br/>Enable current compensation, active high.</p>                                                                                                                                                                                                                                                                                                                               |
| 1     | RW   | 0x1         | <p>res_comp_en<br/>Enable resistance compensation, active high.</p>                                                                                                                                                                                                                                                                                                                                |
| 0     | RW   | 0x1         | <p>squel_trigger_con<br/>bit3 of squel_trigger_con.<br/>4'b0000: 112.5mV<br/>4'b1001: 162.5mV<br/>4'b1011: 175mV<br/>4'b1100: 150mV(default)<br/>4'b1110: 125mV</p>                                                                                                                                                                                                                                |

**GRF\_USBPHY0\_CON2**

Address: Operational Base + offset (0x0288)

usbphy control register

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | <p>write_enable<br/>bit0~bit15 write enable<br/>When bit 16=1, bit 0 can be written by software;<br/>When bit 16=0, bit 0 cannot be written by software;<br/>When bit 17=1, bit 1 can be written by software;<br/>When bit 17=0, bit 1 cannot be written by software;<br/>.....<br/>When bit 31=1, bit 15 can be written by software;<br/>When bit 31=0, bit 15 cannot be written by software.</p> |
| 15         | RW          | 0x1                | <p>odt_compensation<br/>bit 0 of odt_compensation.<br/>ODT Compensation voltage reference<br/>3'b000: 200mV<br/>3'b001: 187.5mV(default)<br/>3'b010: 225mV<br/>3'b110: 175mV<br/>3'b111: 162.5mV</p>                                                                                                                                                                                               |
| 14:13      | RW          | 0x0                | <p>voltage_tolerance_adjust<br/>5V tolerance detection reference adjust, 11 represent the highest trigger point, keeping the default value is greatly appreciated</p>                                                                                                                                                                                                                              |
| 12         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                           |
| 11:10      | RW          | 0x0                | <p>auto_compensation_bypass<br/>auto compensation bypass, 2'b11 will bypass current and ODT compensation, customers can set the driver strength and current manually.<br/>For larger HS eye height, customer can give more "0" for hs_eye_height;<br/>For larger HS/FS/LS slew rate, give more "1" for hfs_driver_strength.</p>                                                                    |
| 9:5        | RW          | 0x15               | <p>hfs_driver_strength<br/>HS/FS driver strength tuning, 5'b11111 represent the largest slew rate and 5'b00000 represents the smallest slew rate</p>                                                                                                                                                                                                                                               |
| 4:0        | RW          | 0x0a               | <p>hs_eye_height<br/>bit7 ~ bit 3 of hs_eye_height.<br/>HS eye height tuning, more zeros represent bigger eye, more ones represent smaller eye</p>                                                                                                                                                                                                                                                 |

**GRF\_USBPHY0\_CON3**

Address: Operational Base + offset (0x028c)  
usbphy control register

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | <p>write_enable<br/>bit0~bit15 write enable<br/>When bit 16=1, bit 0 can be written by software;<br/>When bit 16=0, bit 0 cannot be written by software;<br/>When bit 17=1, bit 1 can be written by software;<br/>When bit 17=0, bit 1 cannot be written by software;<br/>.....<br/>When bit 31=1, bit 15 can be written by software;<br/>When bit 31=0, bit 15 cannot be written by software.</p> |
| 15         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                           |
| 14         | RW          | 0x0                | <p>vol_toleran_det_con<br/>5V tolerance detection function controlling bit through registers,<br/>only active when GRF_USBPHY0_CON4[1] is set "1".</p>                                                                                                                                                                                                                                             |
| 13:10      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                           |
| 9          | RW          | 0x1                | <p>odt_auto_refresh<br/>A port ODT auto refresh bypass, active low, this register should<br/>only be used when auto_compensation_bypass were set to "11".<br/>In bypass mode, customer can configure driver strength through<br/>hfs_driver_strength.</p>                                                                                                                                          |
| 8          | RW          | 0x0                | <p>bg_out_voltage_adjust<br/>BG output voltage reference adjust, keeping the default value is<br/>greatly appreciated.</p>                                                                                                                                                                                                                                                                         |
| 7:5        | RW          | 0x0                | <p>compen_current_ref<br/>compensation current tuning reference<br/>3'b000: 200mV(default)<br/>3'b001: 187.5mV<br/>3'b010: 225mV<br/>3'b110: 175mV<br/>3'b111: 162.5mV</p>                                                                                                                                                                                                                         |
| 4:2        | RW          | 0x0                | <p>bias_current_ref<br/>bias current tuning reference<br/>3'b000: 400mV(default)<br/>3'b001: 362.5mV<br/>3'b010: 350mV<br/>3'b101: 425mV<br/>3'b111: 450mV</p>                                                                                                                                                                                                                                     |
| 1:0        | RW          | 0x0                | <p>odt_compensation<br/>bit 2 ~ bit 1 of odt_compensation.<br/>ODT Compensation voltage reference<br/>3'b000: 200mV<br/>3'b001: 187.5mV(default)<br/>3'b010: 225mV<br/>3'b110: 175mV<br/>3'b111: 162.5mV</p>                                                                                                                                                                                       |

**GRF\_USBPHY0\_CON4**

Address: Operational Base + offset (0x0290)

usbphy control register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_enable<br>bit0~bit15 write enable<br>When bit 16=1, bit 0 can be written by software;<br>When bit 16=0, bit 0 cannot be written by software;<br>When bit 17=1, bit 1 can be written by software;<br>When bit 17=0, bit 1 cannot be written by software;<br>.....<br>When bit 31=1, bit 15 can be written by software;<br>When bit 31=0, bit 15 cannot be written by software. |
| 15:2       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                            |
| 1          | RW          | 0x1                | bypass_5v_tolerance_det<br>Bypass 5V tolerance detection function, active high                                                                                                                                                                                                                                                                                                      |
| 0          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                            |

**GRF\_USBPHY0\_CON5**

Address: Operational Base + offset (0x0294)

usbphy control register

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

**GRF\_USBPHY0\_CON6**

Address: Operational Base + offset (0x0298)

usbphy control register

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------|
| 15:13      | RW          | 0x0                | session_end_con<br>session end reference tuning                                                     |
| 12:10      | RW          | 0x0                | b_session_con<br>B_session valid reference tuning                                                   |
| 9:7        | RW          | 0x0                | a_session_con<br>A_session valid reference tuning                                                   |
| 6          | RW          | 0x0                | force_vbus_valid<br>force output vbus_valid asserted, active high                                   |
| 5          | RW          | 0x0                | force_session_end_val<br>force output session end asserted, active high                             |
| 4          | RW          | 0x0                | force_b_session_val<br>force output B_session valid asserted, active high                           |
| 3          | RW          | 0x0                | force_a_session_val<br>force output A_session valid asserted, active high                           |
| 2          | RW          | 0x1                | turn_off_diff_receiver<br>Turn off differential receiver in suspend mode to save power, active low. |
| 1:0        | RO          | 0x0                | reserved                                                                                            |

**GRF\_USBPHY0\_CON7**

Address: Operational Base + offset (0x029c)

usbphy control register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_enable<br>bit0~bit15 write enable<br>When bit 16=1, bit 0 can be written by software;<br>When bit 16=0, bit 0 cannot be written by software;<br>When bit 17=1, bit 1 can be written by software;<br>When bit 17=0, bit 1 cannot be written by software;<br>.....<br>When bit 31=1, bit 15 can be written by software;<br>When bit 31=0, bit 15 cannot be written by software. |
| 15         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                            |
| 14:11      | RW          | 0xd                | host_discon_con<br>HOST disconnect detection trigger point configure, only used in HOST mode<br>4'b0000: 575mV<br>4'b0001: 600mV<br>4'b1001: 625mV<br>4'b1101: 650mV(default)                                                                                                                                                                                                       |
| 10:8       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                            |
| 7          | RW          | 0x1                | bypass_squelch_trigger<br>bypass squelch trigger point auto configure in chirp modes, active high                                                                                                                                                                                                                                                                                   |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------|
| 6          | RW          | 0x1                | half_bit_pre_empha_en<br>half bit pre-emphasize enable, active high.<br>"1" represent half bit pre-emphasis, "0" for full bit |
| 5:3        | RO          | 0x0                | reserved                                                                                                                      |
| 2:0        | RW          | 0x0                | vbus_valid_con<br>vbus_valid reference tuning                                                                                 |

**GRF\_USBPHY1\_CON0**

Address: Operational Base + offset (0x02a0)

usbphy control register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_enable<br>bit0~bit15 write enable<br>When bit 16=1, bit 0 can be written by software;<br>When bit 16=0, bit 0 cannot be written by software;<br>When bit 17=1, bit 1 can be written by software;<br>When bit 17=0, bit 1 cannot be written by software;<br>.....<br>When bit 31=1, bit 15 can be written by software;<br>When bit 31=0, bit 15 cannot be written by software. |
| 15:13      | RW          | 0x4                | squel_trigger_con<br>bit 2 ~ bit 0 of squel_trigger_con.<br>4'b0000: 112.5mV<br>4'b1001: 162.5mV<br>4'b1011: 175mV<br>4'b1100: 150mV(default)<br>4'b1110: 125mV                                                                                                                                                                                                                     |
| 12:11      | RW          | 0x0                | non_driving<br>Registers for non-driving state control. non-driving state is controlled by op-mode by default, when bit[11] is configured with "1", user can control non-driving state through bit[12].                                                                                                                                                                             |
| 10:8       | RW          | 0x6                | tx_clk_phase_con<br>USB Tx Clock phase configure, 3'b000 represent the earliest phase, and 3'b111 the latest, single step delay is 256ps                                                                                                                                                                                                                                            |
| 7:5        | RW          | 0x0                | rx_clk_phase_con<br>USB Rx Clock phase configure, 3'b000 represent the earliest phase, and 3'b111 the latest, single step delay is 256ps                                                                                                                                                                                                                                            |
| 4:3        | RW          | 0x3                | fsls_eye_height<br>FS/LS eye height configure, 2'b00 represent the largest slew rate, 2'b11 represent the smallest slew rate                                                                                                                                                                                                                                                        |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                               |
|-----|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:0 | RW   | 0x0         | <p>hs_eye_diag_adjust<br/>HS eye diagram adjust, open HS pre-emphasize function to increase HS slew rate, only used when large cap loading is attached.</p> <p>3'b001: open pre-emphasize in sof or eop state<br/>3'b010: open pre-emphasize in chirp state<br/>3'b100: open pre-emphasize in non-chirp state<br/>3'b111: always open pre-emphasize<br/>other combinations : reserved</p> |

**GRF\_USBPHY1\_CON1**

Address: Operational Base + offset (0x02a4)

usbphy control register

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                        |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0x0000      | <p>write_enable<br/>bit0~bit15 write enable<br/>When bit 16=1, bit 0 can be written by software;<br/>When bit 16=0, bit 0 cannot be written by software;<br/>When bit 17=1, bit 1 can be written by software;<br/>When bit 17=0, bit 1 cannot be written by software;<br/>.....<br/>When bit 31=1, bit 15 can be written by software;<br/>When bit 31=0, bit 15 cannot be written by software.</p> |
| 15:13 | RW   | 0x7         | <p>hs_eye_height<br/>bit2 ~ bit 0 of hs_eye_height.<br/>HS eye height tuning, more zeros represent bigger eye, more ones represent smaller eye</p>                                                                                                                                                                                                                                                 |
| 12:3  | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                           |
| 2     | RW   | 0x1         | <p>current_comp_en<br/>Enable current compensation, active high.</p>                                                                                                                                                                                                                                                                                                                               |
| 1     | RW   | 0x1         | <p>res_comp_en<br/>Enable resistance compensation, active high.</p>                                                                                                                                                                                                                                                                                                                                |
| 0     | RW   | 0x1         | <p>squel_trigger_con<br/>bit 3 of squel_trigger_con.<br/>4'b0000: 112.5mV<br/>4'b1001: 162.5mV<br/>4'b1011: 175mV<br/>4'b1100: 150mV(default)<br/>4'b1110: 125mV</p>                                                                                                                                                                                                                               |

**GRF\_USBPHY1\_CON2**

Address: Operational Base + offset (0x02a8)

usbphy control register

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

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                        |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0x0000      | <p>write_enable<br/>bit0~bit15 write enable<br/>When bit 16=1, bit 0 can be written by software;<br/>When bit 16=0, bit 0 cannot be written by software;<br/>When bit 17=1, bit 1 can be written by software;<br/>When bit 17=0, bit 1 cannot be written by software;<br/>.....<br/>When bit 31=1, bit 15 can be written by software;<br/>When bit 31=0, bit 15 cannot be written by software.</p> |
| 15    | RW   | 0x1         | <p>odt_compensation<br/>bit 0 of odt_compensation.<br/>ODT Compensation voltage reference<br/>3'b000: 200mV<br/>3'b001: 187.5mV(default)<br/>3'b010: 225mV<br/>3'b110: 175mV<br/>3'b111: 162.5mV</p>                                                                                                                                                                                               |
| 14:13 | RW   | 0x0         | <p>voltage_tolerance_adjust<br/>5V tolerance detection reference adjust, 2'b11 represent the highest trigger point, keeping the default value is greatly appreciated</p>                                                                                                                                                                                                                           |
| 12    | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                           |
| 11:10 | RW   | 0x0         | <p>auto_compensation_bypass<br/>auto compensation bypass, 2'b11 will bypass current and ODT compensation, customers can set the driver strength and current manually.<br/>For larger HS eye height, customer can give more "0" for hs_eye_height;<br/>For larger HS/FS/LS slew rate, give more "1" for hfs_driver_strength.</p>                                                                    |
| 9:5   | RW   | 0x15        | <p>hfs_driver_strength<br/>HS/FS driver strength tuning , 5'b11111 represent the largest slew rate and 5'b10000 represents the smallest slew rate</p>                                                                                                                                                                                                                                              |
| 4:0   | RW   | 0x0a        | <p>hs_eye_height<br/>bit7 ~ bit 3 of hs_eye_height.<br/>HS eye height tuning, more zeros represent bigger eye, more ones represent smaller eye</p>                                                                                                                                                                                                                                                 |

**GRF\_USBPHY1\_CON3**

Address: Operational Base + offset (0x02ac)  
usbphy control register

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | <p>write_enable<br/>bit0~bit15 write enable<br/>When bit 16=1, bit 0 can be written by software;<br/>When bit 16=0, bit 0 cannot be written by software;<br/>When bit 17=1, bit 1 can be written by software;<br/>When bit 17=0, bit 1 cannot be written by software;<br/>.....<br/>When bit 31=1, bit 15 can be written by software;<br/>When bit 31=0, bit 15 cannot be written by software.</p> |
| 15         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                           |
| 14         | RW          | 0x0                | <p>vol_toleran_det_con<br/>5V tolerance detection function controlling bit through registers,<br/>only active when GRF_USBPHY0_CON4[1] is set 1'b1.</p>                                                                                                                                                                                                                                            |
| 13:10      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                           |
| 9          | RW          | 0x1                | <p>odt_auto_refresh<br/>A port ODT auto refresh bypass, active low, this register should<br/>only be used when auto_compensation_bypass were set to 2'b11.<br/>In bypass mode, customer can configure driver strength through<br/>hfs_driver_strength.</p>                                                                                                                                         |
| 8          | RW          | 0x0                | <p>bg_out_voltage_adjust<br/>BG output voltage reference adjust, keeping the default value is<br/>greatly appreciated.</p>                                                                                                                                                                                                                                                                         |
| 7:5        | RW          | 0x0                | <p>compen_current_ref<br/>compensation current tuning reference<br/>3'b000: 200mV(default)<br/>3'b001: 187.5mV<br/>3'b010: 225mV<br/>3'b110: 175mV<br/>3'b111: 162.5mV</p>                                                                                                                                                                                                                         |
| 4:2        | RW          | 0x0                | <p>bias_current_ref<br/>bias current tuning reference<br/>3'b000: 400mV(default)<br/>3'b001: 362.5mV<br/>3'b010: 350mV<br/>3'b101: 425mV<br/>3'b111: 450mV</p>                                                                                                                                                                                                                                     |
| 1:0        | RW          | 0x0                | <p>odt_compensation<br/>bit 2 ~ bit 1 of odt_compensation.<br/>ODT Compensation voltage reference<br/>3'b000: 200mV<br/>3'b001: 187.5mV(default)<br/>3'b010: 225mV<br/>3'b110: 175mV<br/>3'b111: 162.5mV</p>                                                                                                                                                                                       |

**GRF\_USBPHY1\_CON4**

Address: Operational Base + offset (0x02b0)

usbphy control register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_enable<br>bit0~bit15 write enable<br>When bit 16=1, bit 0 can be written by software;<br>When bit 16=0, bit 0 cannot be written by software;<br>When bit 17=1, bit 1 can be written by software;<br>When bit 17=0, bit 1 cannot be written by software;<br>.....<br>When bit 31=1, bit 15 can be written by software;<br>When bit 31=0, bit 15 cannot be written by software. |
| 15:2       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                            |
| 1          | RW          | 0x1                | bypass_5v_tolerance_det<br>Bypass 5V tolerance detection function, active high                                                                                                                                                                                                                                                                                                      |
| 0          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                            |

**GRF\_USBPHY1\_CON5**

Address: Operational Base + offset (0x02b4)

usbphy control register

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

**GRF\_USBPHY1\_CON6**

Address: Operational Base + offset (0x02b8)

usbphy control register

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------|
| 15:13      | RW          | 0x0                | session_end_con<br>session end reference tuning                                                     |
| 12:10      | RW          | 0x0                | b_session_con<br>B_session valid reference tuning                                                   |
| 9:7        | RW          | 0x0                | a_session_con<br>A_session valid reference tuning                                                   |
| 6          | RW          | 0x0                | force_vbus_valid<br>force output vbus_valid asserted, active high                                   |
| 5          | RW          | 0x0                | force_session_end_val<br>force output session end asserted, active high                             |
| 4          | RW          | 0x0                | force_b_session_val<br>force output B_session valid asserted, active high                           |
| 3          | RW          | 0x0                | force_a_session_val<br>force output A_session valid asserted, active high                           |
| 2          | RW          | 0x1                | turn_off_diff_receiver<br>Turn off differential receiver in suspend mode to save power, active low. |
| 1:0        | RO          | 0x0                | reserved                                                                                            |

**GRF\_USBPHY1\_CON7**

Address: Operational Base + offset (0x02bc)

usbphy control register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_enable<br>bit0~bit15 write enable<br>When bit 16=1, bit 0 can be written by software;<br>When bit 16=0, bit 0 cannot be written by software;<br>When bit 17=1, bit 1 can be written by software;<br>When bit 17=0, bit 1 cannot be written by software;<br>.....<br>When bit 31=1, bit 15 can be written by software;<br>When bit 31=0, bit 15 cannot be written by software. |
| 15         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                            |
| 14:11      | RW          | 0xd                | host_discon_con<br>HOST disconnect detection trigger point configure, only used in HOST mode<br>4'b0000: 575mV<br>4'b0001: 600mV<br>4'b1001: 625mV<br>4'b1101: 650mV(default)                                                                                                                                                                                                       |
| 10:8       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                            |
| 7          | RW          | 0x1                | bypass_squelch_trigger<br>bypass squelch trigger point auto configure in chirp modes, active high                                                                                                                                                                                                                                                                                   |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------|
| 6          | RW          | 0x1                | half_bit_pre_empha_en<br>half bit pre-emphasize enable, active high.<br>"1" represent half bit pre-emphasis, "0" for full bit |
| 5:3        | RO          | 0x0                | reserved                                                                                                                      |
| 2:0        | RW          | 0x0                | vbus_valid_con<br>vbus_valid reference tuning                                                                                 |

**GRF\_CHIP\_TAG**

Address: Operational Base + offset (0x0300)

chip tag register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>   |
|------------|-------------|--------------------|----------------------|
| 31:0       | RO          | 0x00003012         | chip_tag<br>Chip tag |

**GRF\_SDMMC\_DET\_CNT**

Address: Operational Base + offset (0x0304)

SDMMC detectn filter count

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------|
| 31:20      | RO          | 0x0                | reserved                                                                                                                      |
| 19:0       | RW          | 0x00cff            | sdmmc_detn_cnt<br>SDMMC detectn filter count. Number of XIN24M clock, used for the detect of sdmmc card when grf_force_jtag=1 |

**GRF\_EFUSE\_PRG**

Address: Operational Base + offset (0x037c)

eFuse program enable register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------|
| 31:14      | RO          | 0x0                | reserved                                                              |
| 13         | WO          | 0x0                | eFuse program enable<br>1'b1: enable program<br>1'b0: disable program |
| 12:0       | RO          | 0x0                | reserved                                                              |

## Chapter 6 DMC (Dynamic Memory Interface)

### 6.1 Overview

The DMC includes two section: dynamic ram protocol controller (PCTL) and PHY controller. The PCTL SoC application bus interface supports a lowest-latency native application interface (NIF). To maximize data transfer efficiency, NIF commands transfer data without flow control. To simplify command processing, the NIF accepts addresses in rank, bank, row, column format.

The DDR PHY provides control features to ease the customer implementation of digitally controlled features of the PHY such as initialization, DQS gate training, and programmable configuration controls. The DDR PHY has built-in self-test features to provide support for production testing of the compatible PHY. It also provides a DFI 2.1 interface to the PHY.

The DMC supports the following features:

- Complete, integrated DDR3 solution
- DFI 2.1 interface compatibility
- Up to 800 Mbps in 1:1 frequency ratio, using a 400MHz controller clock and 400MHz memory clock.
- Support for x8, x16 memories, for a total memory data path width of 16 bits
- Up to 2 memory ranks; devices within a rank tie to a common chip select
- Up to 8 open memory banks, maximum of eight per rank
- Per-NIF transaction controllable bank management policies: open-page, close-page
- Low area, low power architecture with minimal buffering on the data, avoiding duplication of storage resources within the system
- PCTL NIF slave interface facilitates easy integration with an external scheduler or standard on-chip buses
- Efficient DDR protocol implementation with in-order column (Read and Write) commands and out-of-order Activate and Precharge commands
- Three clock cycles best case command latency (best case is when a command is to an open page and the shift array in the PCTL is empty)
- 1T or 2T memory command timing
- Automatic power-down and self-refresh entry and exit
- Software and hardware driven self-refresh entry and exit
- Programmable memory initialization
- Partial population of memories, where not all DDR byte lanes are populated with memory chips
- Programmable per rank memory ODT (On-Die Termination) support for reads and writes
- APB interface for controller software-accessible registers
- Programmable data training interface:
  - Assists in training of the data eye of the memory channel
  - Provides a method for testing large sections of memory
  - Automatic DQS gate training
- At-speed built-in-self-test (BIST) loopback testing on both the address and data channels for DDR PHYs
- PHY control and configuration registers
- Optional, additional JTAG interface to configure registers

## 6.2 Block Diagram



Fig. 6-1 Protocol controller architecture



Fig. 6-2 PHY controller architecture

## 6.3 Function Description

### 6.3.1 Protocol controller (PCTL)

PCTL operations are defined in terms of the current state of the Operational State Machine. Software can move PCTL in any of the operational states by issuing commands via the SCTL register. Transitions from one operational state to the other occur pass through a “transitional” state. Transitional states are exited automatically by the PCTL after all the necessary actions required to change operational state have been completed. The current operational state of PCTL is reported by the STAT register and is also available from the p\_ctl\_stat output.

PCTL supports the following operational states:

- Init\_mem - This state is the default state entered after reset. All writable registers can be programmed. While in this state software can program PCTL and initialize the PHY and the memories. The memories are not refreshed and data that has previously been written to the memories may be lost as a result. The Init\_mem state is also used when it is desirable to stop any automatic PCTL function that directly affects the memories, like Power Down and Refresh, or when a software reset of the memory subsystem has to be executed.
- ConFig - This state is used to suspend temporarily the normal NIF traffic and allow software to reprogram PCTL and memories if necessary, while still keeping active the periodic generation of Refresh cycles to the memories. Power Down entry and exit sequences are possible while in ConFig state.
- Access - This is the operational state where NIF transactions are accepted by the PCTL and converted into memory read and writes. None of the registers can be programmed except SCFG, SCTL, ECCCLR and DTU\* registers.
- Low\_power - Memories are in self-refresh mode. The PCTL does not generate refresh cycles while in this state.

Access and Low\_power states can also be entered and exited by the hardware low power signals (c\_\*)<sup>1</sup>. In case of conflicting software and hardware low-power commands, the resulting operational state taken by the controller can be either one of the two conflicting requests.

Figure 1-3 illustrates the operational and transitional states.



Fig. 6-3 Protocol controller architecture

The controller clock is the same clock driving the memory controller and will be the same frequency as the SDRAM clock (ck). The configuration clock can run at a frequency equal to or less than the controller clock. The configuration clock drives all non-DDR timing logic, such as configuration registers, PHY initialization, output impedance, and so on.

### 6.3.2 DDR PHY

DDR PHY provides turn key physical interface solutions for chip requiring access to DDR3 SDRAM device. It is optimized for low power and high speed (up to 800Mbps for DDR3) applications with robust timing and small silicon area. It supports DDR3 SDRAM components in the market. The PHY components contain DDR specialized functional and utility SSTL I/Os up to 800MHz, critical timing synchronization module (TSM) and a low power/jitter DLLs with programmable fine-grain control for any SDRAM interface.

DDR PHY uses a DFI digital interface to connect the memory controller. All interface timing is in 1X SDR clock domain. The controller to PHY interface is running at single data rate (SDR) therefore read/write bus is double width. DDR muxing is done in the PHY block together with all related per-byte lane timing adjustment. The interface is fairly generic and support high performance input and output data flow gearing toward 100Mbps to 800Mbps DDR3 SDRAM speed in wide range.

With configurable timing and driving strength and ODT parameters to interface to the wide variety of SDRAMs, the PHY is very flexible with advanced command capability to increase SDRAM operation efficiency.

## 6.4 Register Description

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

### 6.4.1 Registers Summary

| Name                | Offset | Size | Reset Value | Description                                         |
|---------------------|--------|------|-------------|-----------------------------------------------------|
| DDR_PCTL_SCFG       | 0x0000 | W    | 0x00000300  | State Configuration Register                        |
| DDR_PCTL_SCTL       | 0x0004 | W    | 0x00000000  | Operational State Control Register                  |
| DDR_PCTL_STAT       | 0x0008 | W    | 0x00000000  | Operational State Status Register                   |
| DDR_PCTL_INTRSTAT   | 0x000c | W    | 0x00000000  | Interrupt Status Register                           |
| DDR_PCTL_MCMD       | 0x0040 | W    | 0x00100000  | Memory Command Register                             |
| DDR_PCTL_POWCTL     | 0x0044 | W    | 0x00000000  | Power Up Control Register                           |
| DDR_PCTL_POWSTAT    | 0x0048 | W    | 0x00000000  | Power Up Status Register                            |
| DDR_PCTL_CMDTSTAT   | 0x004c | W    | 0x00000000  | Command Timers Status Register                      |
| DDR_PCTL_CMDTSTATEN | 0x0050 | W    | 0x00000000  | Command Timers Status Enable Register               |
| DDR_PCTL_MRRCFG0    | 0x0060 | W    | 0x00000000  | Mode Register Read Configuration 0                  |
| DDR_PCTL_MRRSTAT0   | 0x0064 | W    | 0x00000000  | Mode Register Read Status 0 Register                |
| DDR_PCTL_MRRSTAT1   | 0x0068 | W    | 0x00000000  | Mode Register Read Status 0 Register                |
| DDR_PCTL_MCFG       | 0x0080 | W    | 0x00040020  | Memory Configuration Register                       |
| DDR_PCTL_PPCFG      | 0x0084 | W    | 0x00000000  | Partially Populated Memories Configuration Register |
| DDR_PCTL_MSTAT      | 0x0088 | W    | 0x00000000  | Memory Status Register                              |
| DDR_PCTL_MCFG1      | 0x0090 | W    | 0x00000000  | Memory Configuration 1 Register                     |
| DDR_PCTL_DTUPDES    | 0x0094 | W    | 0x00000000  | DTU Status Register                                 |
| DDR_PCTL_DTUNA      | 0x0098 | W    | 0x00000000  | DTU Number of Addresses Created Register            |
| DDR_PCTL_DTUNE      | 0x009c | W    | 0x00000000  | DTU Number of Errors Register                       |
| DDR_PCTL_DTUPRD0    | 0x00a0 | W    | 0x00000000  | DTU Parallel Read 0 Register                        |
| DDR_PCTL_DTUPRD1    | 0x00a4 | W    | 0x00000000  | DTU Parallel Read 1 Register                        |
| DDR_PCTL_DTUPRD2    | 0x00a8 | W    | 0x00000000  | DTU Parallel Read 2 Register                        |
| DDR_PCTL_DTUPRD3    | 0x00ac | W    | 0x00000000  | DTU Parallel Read 3 Register                        |
| DDR_PCTL_DTUAWDT    | 0x00b0 | W    | 0x00000290  | DTU Address Width Register                          |
| DDR_PCTL_TOGCNT1U   | 0x00c0 | W    | 0x00000064  | Toggle Counter 1us Register                         |
| DDR_PCTL_TINIT      | 0x00c4 | W    | 0x000000c8  | t_init Timing Register                              |
| DDR_PCTL_TRSTH      | 0x00c8 | W    | 0x00000000  | t_rsth Timing Register                              |
| DDR_PCTL_TOGCNT100N | 0x00cc | W    | 0x00000001  | Toggle Counter 100ns                                |
| DDR_PCTL_TREFI      | 0x00d0 | W    | 0x00000001  | t_refi Timing Register                              |
| DDR_PCTL_TMRD       | 0x00d4 | W    | 0x00000001  | t_mrd Timing Register                               |
| DDR_PCTL_TRFC       | 0x00d8 | W    | 0x00000001  |                                                     |
| DDR_PCTL_TRP        | 0x00dc | W    | 0x00010006  | t_trp Timing Register                               |
| DDR_PCTL_TRTW       | 0x00e0 | W    | 0x00000002  | t_rtw Timing Register                               |
| DDR_PCTL_TAL        | 0x00e4 | W    | 0x00000000  | AL Register                                         |

| Name                   | Offset | Size | Reset Value | Description                                      |
|------------------------|--------|------|-------------|--------------------------------------------------|
| DDR_PCTL_TCL           | 0x00e8 | W    | 0x00000004  | CL Timing Register                               |
| DDR_PCTL_TCWL          | 0x00ec | W    | 0x00000003  | CWL Timing Register                              |
| DDR_PCTL_TRAS          | 0x00f0 | W    | 0x00000010  | t_ras Timing Register                            |
| DDR_PCTL_TRC           | 0x00f4 | W    | 0x00000016  | t_rc Timing Register                             |
| DDR_PCTL_TRCD          | 0x00f8 | W    | 0x00000006  | t_rcd Timing Register                            |
| DDR_PCTL_TRRD          | 0x00fc | W    | 0x00000004  | t_rrd Timing Register                            |
| DDR_PCTL_TRTP          | 0x0100 | W    | 0x00000003  | t_rtp Timing Register                            |
| DDR_PCTL_TWR           | 0x0104 | W    | 0x00000006  | t_wr Register                                    |
| DDR_PCTL_TWTR          | 0x0108 | W    | 0x00000004  | t_wtr Timing Register                            |
| DDR_PCTL_TEXSR         | 0x010c | W    | 0x00000001  | t_exsr Timing Register                           |
| DDR_PCTL_TXP           | 0x0110 | W    | 0x00000001  | t_xp Timing Register                             |
| DDR_PCTL_TXPDLL        | 0x0114 | W    | 0x00000000  | t_xpdll Timing Register                          |
| DDR_PCTL_TZQCS         | 0x0118 | W    | 0x00000000  | t_zqcs Timing Register                           |
| DDR_PCTL_TZQCSI        | 0x011c | W    | 0x00000000  | t_zqcsi Timing Register                          |
| DDR_PCTL_TDQS          | 0x0120 | W    | 0x00000001  | t_dqs Timing Register                            |
| DDR_PCTL_TCKSRE        | 0x0124 | W    | 0x00000000  | t_cksre Timing Register                          |
| DDR_PCTL_TCKSRX        | 0x0128 | W    | 0x00000000  | t_cksrx Timing Register                          |
| DDR_PCTL_TCKE          | 0x012c | W    | 0x00000003  | t_cke Timing Register                            |
| DDR_PCTL_TMOD          | 0x0130 | W    | 0x00000000  | t_mod Timing Register                            |
| DDR_PCTL_TRSTL         | 0x0134 | W    | 0x00000000  | Reset Low Timing Register                        |
| DDR_PCTL_TZQCL         | 0x0138 | W    | 0x00000000  | t_zqcl Timing Register                           |
| DDR_PCTL_TMRR          | 0x013c | W    | 0x00000002  | t_mrr Timing Register                            |
| DDR_PCTL_TCKESR        | 0x0140 | W    | 0x00000004  | t_ckesr Timing Register                          |
| DDR_PCTL_TDPD          | 0x0144 | W    | 0x00000000  | t_dpd Timing Register                            |
| DDR_PCTL_DTUWACTL      | 0x0200 | W    | 0x00000000  | DTU Write Address Control                        |
| DDR_PCTL_DTURACTL      | 0x0204 | W    | 0x00000000  | DTU Read Address Control Register                |
| DDR_PCTL_DTUCFG        | 0x0208 | W    | 0x00000000  | DTU Configuration Control Register               |
| DDR_PCTL_DTUECTL       | 0x020c | W    | 0x00000000  | DTU Execute Control Register                     |
| DDR_PCTL_DTUWD0        | 0x0210 | W    | 0x00000000  | DTU Write Data #0 Register                       |
| DDR_PCTL_DTUWD1        | 0x0214 | W    | 0x00000000  | DTU Write Data #1 Register                       |
| DDR_PCTL_DTUWD2        | 0x0218 | W    | 0x00000000  | DTU Write Data #2 Register                       |
| DDR_PCTL_DTUWD3        | 0x021c | W    | 0x00000000  | DTU Write Data #3 Register                       |
| DDR_PCTL_DTUWDM        | 0x0220 | W    | 0x00000000  | DTU Write Data Mask Register                     |
| DDR_PCTL_DTURD0        | 0x0224 | W    | 0x00000000  | DTU Read Data #0 Register                        |
| DDR_PCTL_DTURD1        | 0x0228 | W    | 0x00000000  | DTU Read Data #1 Register                        |
| DDR_PCTL_DTURD2        | 0x022c | W    | 0x00000000  | DTU Read Data #2 Register                        |
| DDR_PCTL_DTURD3        | 0x0230 | W    | 0x00000000  | DTU Read Data #3 Register                        |
| DDR_PCTL_DTULFSRW      | 0x0234 | W    | 0x00000000  | DTU LFSR Seed for Write Data Generation Register |
| DDR_PCTL_DTULFSRR      | 0x0238 | W    | 0x00000000  | DTU LFSR Seed for Read Data Generation Register  |
| DDR_PCTL_DTUEAF        | 0x023c | W    | 0x00000000  | DTU Error Address FIFO Register                  |
| DDR_PCTL_DFITCTRLDELAY | 0x0240 | W    | 0x00000002  | DFI tctrl_delay Register                         |
| DDR_PCTL_DFIODTCFG     | 0x0244 | W    | 0x00000000  | DFI ODT Configuration                            |

| Name                      | Offset | Size | Reset Value | Description                                             |
|---------------------------|--------|------|-------------|---------------------------------------------------------|
| DDR_PCTL_DFIODTCFG1       | 0x0248 | W    | 0x06060000  | DFI ODT Timing Configuration 1 (for Latency and Length) |
| DDR_PCTL_DFIODTRANKMAP    | 0x024c | W    | 0x00008421  | DFI ODT Rank Mapping                                    |
| DDR_PCTL_DFITPHYWRDATA    | 0x0250 | W    | 0x00000001  | DFI tphy_wrdata Register                                |
| DDR_PCTL_DFITPHYWRLAT     | 0x0254 | W    | 0x00000001  | DFI tphy_wrlat Register                                 |
| DDR_PCTL_DFITRDDATAEN     | 0x0260 | W    | 0x00000001  | DFI trddata_en Register                                 |
| DDR_PCTL_DFITPHYRDLAT     | 0x0264 | W    | 0x0000000f  | DFI tphy_rdlat Register                                 |
| DDR_PCTL_DFITPHYUPDTYPE0  | 0x0270 | W    | 0x00000010  | DFI tphyupd_type0 Register                              |
| DDR_PCTL_DFITPHYUPDTYPE1  | 0x0274 | W    | 0x00000010  | DFI tphyupd_type1 Register                              |
| DDR_PCTL_DFITPHYUPDTYPE2  | 0x0278 | W    | 0x00000010  | DFI tphyupd_type2 Register                              |
| DDR_PCTL_DFITPHYUPDTYPE3  | 0x027c | W    | 0x00000010  | DFI tphyupd_type3 Register                              |
| DDR_PCTL_DFITCTRLUPDMIN   | 0x0280 | W    | 0x00000010  | DFI tctrlupd_min Register                               |
| DDR_PCTL_DFITCTRLUPDMAX   | 0x0284 | W    | 0x00000040  | DFI tctrlupd_max Register                               |
| DDR_PCTL_DFITCTRLUPDDLY   | 0x0288 | W    | 0x00000008  | DFI tctrlupddly Register                                |
| DDR_PCTL_DFIUPDCFG        | 0x0290 | W    | 0x00000003  | DFI Update Configuration Register                       |
| DDR_PCTL_DFITREFMSKI      | 0x0294 | W    | 0x00000000  | DFI Masked Refresh Interval                             |
| DDR_PCTL_DFITCTRLUPDI     | 0x0298 | W    | 0x00000000  | DFI tctrlupd_interval Register                          |
| DDR_PCTL_DFITRCFG0        | 0x02ac | W    | 0x00000000  | DFI Training Configuration 0 Register                   |
| DDR_PCTL_DFITRSTAT0       | 0x02b0 | W    | 0x00000000  | DFI Training Status 0 Register                          |
| DDR_PCTL_DFITRWRLVLEN     | 0x02b4 | W    | 0x00000000  | DFI Training dfi_wrlvl_en Register                      |
| DDR_PCTL_DFITRRDLVLEN     | 0x02b8 | W    | 0x00000000  | DFI Training dfi_rdlvl_en Register                      |
| DDR_PCTL_DFITRRDLVLGATEEN | 0x02bc | W    | 0x00000000  | DFI Training dfi_rdlvl_gate_en Register                 |
| DDR_PCTL_DFISTSTAT0       | 0x02c0 | W    | 0x00000000  | DFI Status Status 0 Register                            |
| DDR_PCTL_DFISTCFG0        | 0x02c4 | W    | 0x00000000  | DFI Status Configuration 0 Register                     |
| DDR_PCTL_DFISTCFG1        | 0x02c8 | W    | 0x00000000  | DFI Status Configuration 1 Register                     |

| Name                         | Offset | Size | Reset Value | Description                                           |
|------------------------------|--------|------|-------------|-------------------------------------------------------|
| DDR_PCTL_DFIDRAMCLKEN        | 0x02d0 | W    | 0x00000002  | DFI tdram_clk_enable Register                         |
| DDR_PCTL_DFIDRAMCLKDIS       | 0x02d4 | W    | 0x00000002  | DFI tdram_clk_disable Register                        |
| DDR_PCTL_DFISTCFG2           | 0x02d8 | W    | 0x00000000  | DFI Status Configuration 2 Register                   |
| DDR_PCTL_DFISTPARCLR         | 0x02dc | W    | 0x00000000  | DFI Status Parity Clear Register                      |
| DDR_PCTL_DFISTPARLOG         | 0x02e0 | W    | 0x00000000  | DFI Status Parity Log Register                        |
| DDR_PCTL_DFLPCFG0            | 0x02f0 | W    | 0x00070000  | DFI Low Power Configuration 0 Register                |
| DDR_PCTL_DFITRWRLVLERSP0     | 0x0300 | W    | 0x00000000  | DFI Training dfi_wrlvl_resp Status 0 Register         |
| DDR_PCTL_DFITRWRLVLERSP1     | 0x0304 | W    | 0x00000000  | DFI Training dfi_wrlvl_resp Status 1 Register         |
| DDR_PCTL_DFITRWRLVLERSP2     | 0x0308 | W    | 0x00000000  | DFI Training dfi_wrlvl_resp Status 2 Register         |
| DDR_PCTL_DFITRRDLVLERSP0     | 0x030c | W    | 0x00000000  | DFI Training dfi_rdlvl_resp Status 0 Register         |
| DDR_PCTL_DFITRRDLVLERSP1     | 0x0310 | W    | 0x00000000  | DFI Training dfi_rdlvl_resp Status 1 Register         |
| DDR_PCTL_DFITRRDLVLERSP2     | 0x0314 | W    | 0x00000000  | DFI Training dfi_rdlvl_resp Status 2 Register         |
| DDR_PCTL_DFITRWRLVLEDLAY0    | 0x0318 | W    | 0x00000000  | DFI Training dfi_wrlvl_delay Configuration 0 Register |
| DDR_PCTL_DFITRWRLVLEDLAY1    | 0x031c | W    | 0x00000000  | DFI Training dfi_wrlvl_delay Configuration 1 Register |
| DDR_PCTL_DFITRWRLVLEDLAY2    | 0x0320 | W    | 0x00000000  | DFI Training dfi_wrlvl_delay Configuration 2 Register |
| DDR_PCTL_DFITRRDLVLEDLAY0    | 0x0324 | W    | 0x00000000  | DFI Training dfi_rdlvl_delay Configuration 0 Register |
| DDR_PCTL_DFITRRDLVLEDLAY1    | 0x0328 | W    | 0x00000000  | DFI Training dfi_rdlvl_delay Configuration 1 Register |
| DDR_PCTL_DFITRRDLVLEDLAY2    | 0x032c | W    | 0x00000000  | DFI Training dfi_rdlvl_delay Configuration 2 Register |
| DDR_PCTL_DFITRRDLVLGATEDLAY0 | 0x0330 | W    | 0x00000000  | DFI Training dfi_rdlvl_gate_delay Configuration 0     |
| DDR_PCTL_DFITRRDLVLGATEDLAY1 | 0x0334 | W    | 0x00000000  | DFI Training dfi_rdlvl_gate_delay Configuration 1     |
| DDR_PCTL_DFITRRDLVLGATEDLAY2 | 0x0338 | W    | 0x00000000  | DFI Training dfi_rdlvl_gate_delay Configuration 2     |
| DDR_PCTL_DFITRCMD            | 0x033c | W    | 0x00000000  | DFI Training Command Register                         |
| DDR_PCTL_IPVR                | 0x03f8 | W    | 0x00000000  | IP Version Register                                   |
| DDR_PCTL_IPTR                | 0x03fc | W    | 0x44574300  | IP Type Register                                      |

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

### 6.4.2 Detail Register Description

#### DDR\_PCTL\_SCFG

Address: Operational Base + offset (0x0000)

State Configuration Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:12      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 11:8       | RW          | 0x3                | <p><b>bbflags_timing</b><br/> The n_bbflags is a NIF output vector which provides combined information about the status of each memory bank. The de-assertion is based on when precharge, activates, reads/writes are scheduled by the TCU block. It may be possible to de-assert n_bbflags earlier than calculated by the TCU block. Programming bbflags_timing is used to achieve this. The maximum recommended value is: TRP.t_rp. The programmed value is the maximum number of "early" cycles that n_bbflags maybe de-asserted. The actual achieved de-assertion depends on the traffic profile.</p>                                                                                                          |
| 7          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 6          | RW          | 0x0                | <p><b>nfifo_nif1_dis</b><br/> For internal use only for NFIFO testing.<br/> 1'b0 = Only supported setting.<br/> 1'b1 = For internal use only.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 5:1        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 0          | RW          | 0x0                | <p><b>hw_low_power_en</b><br/> Enables the hardware low-power interface. Allows the system to request via hardware (c_sysreq input) to enter the memories into Self-Refresh. The handshaking between the request and acknowledge hardware low power signals (c_sysreq and c_sysack, respectively) is always performed, but the ddr controller response depends on the value set on this register field and by the value driven on the c_active_in input pin.<br/> 1'b0 = Disabled. Requests are always denied and ddr controller is unaffected by c_sysreq<br/> 1'b1 = Enabled. Requests are accepted or denied, depending on the current operational state of ddr controller and on the value of c_active_in.</p> |

#### DDR\_PCTL\_SCTL

Address: Operational Base + offset (0x0004)

Operational State Control Register

| <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:0        | RW          | 0x0                | <p>state_cmd<br/>Issues an operational state transition request to the controller.<br/>3'b000 = INIT (move to Init_mem from Config)<br/>3'b001 = CFG (move to ConFig from Init_mem or Access)<br/>3'b010 = GO (move to Access from Config)<br/>3'b011 = SLEEP (move to Low_power from Access)<br/>3'b100 = WAKEUP (move to Access from Low_power)<br/>Others = Reserved</p> |

**DDR\_PCTL\_STAT**

Address: Operational Base + offset (0x0008)

Operational State Status Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:7       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 6:4        | RO          | 0x0                | <p>lp_trig<br/>Reports the status of what triggered an entry to Low_power state.<br/>Is only set if in Low_power state. The individual bits report the following:<br/>           - lp_trig[2]: Software driven due to SCTL.state_cmd==SLEEP.<br/>           - lp_trig[1]: Hardware driven due to Hardware Low Power Interface.<br/>           - lp_trig[0]: Hardware driven due to Auto Self-Refresh (MCFG1.sr_idle&gt;0).<br/>Note, if more than one trigger happens at the exact same time, more than one bit of lp_trig may be asserted high.</p> |
| 3          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 2:0        | RO          | 0x0                | <p>ctl_stat<br/>Returns the current operational state of the controller.<br/>3'b000 = Init_mem<br/>3'b001 = ConFig<br/>3'b010 = Config_req<br/>3'b011 = Access<br/>3'b100 = Access_req<br/>3'b101 = Low_power<br/>3'b110 = Low_power_entry_req<br/>3'b111 = Low_power_exit_req<br/>Others = Reserved</p>                                                                                                                                                                                                                                             |

**DDR\_PCTL\_INTRSTAT**

Address: Operational Base + offset (0x000c)

Interrupt Status Register

| <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          | RO          | 0x0                | parity_intr<br>Indicates that a DFI parity error has been detected<br>1'b0 = No error<br>1'b1 = Parity error |
| 0          | RO          | 0x0                | ecc_intr<br>Indicates that an ECC error has been detected<br>1'b0 = No error<br>1'b1 = Parity error          |

**DDR\_PCTL\_MCMD**

Address: Operational Base + offset (0x0040)

Memory Command Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | R/W SC      | 0x0                | start_cmd<br>Start command. When this bit is set to 1, the command operation defined in the cmd_opcode field is started. This bit is automatically cleared by the controller after the command is finished. The application can poll this bit to determine when controller is ready to accept another command. This bit cannot be cleared to 1'b0 by software.                                                           |
| 30:28      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 27:24      | RW          | 0x0                | cmd_add_del<br>Set the additional delay associated with each command to $2^n$ internal timers clock cycles, where n is the bit field value. If n=0, the delay is 0. Max value is n=10.                                                                                                                                                                                                                                   |
| 23:20      | RW          | 0x1                | rank_sel<br>Rank select for the command to be executed.<br>4'b0001 = Rank 0<br>4'b0010 = Rank 1<br>Others are reserved.<br>Multiple 1'b1s in rank_sel mean multiple ranks are selected, which is useful broadcasting commands in parallel to multiple ranks during initialization and configuration of the memories. If MCMD.cmd_opcode=RSTL, all ranks should be selected as it cannot be performed to individual ranks |
| 19:17      | RW          | 0x0                | bank_addr<br>Mode Register address driven on the memory bank address bits, BA1, BA0, during a Mode Register Set operation, defined by cmd_opcode=MRS. For other values of cmd_opcode, this field is ignored.<br>3'b000 = MR0<br>3'b001 = MR1<br>3'b010 = MR2<br>3'b011 = MR3<br>Others = Reserved                                                                                                                        |

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16:4 | RW   | 0x0000      | cmd_addr<br>Mode Register value driven on the memory address bits, A12 to A0, during a Mode Register Set operation defined by cmd_opcode = MRS. For other values of cmd_opcode this field is ignored. Refer to the memory specification for the correct settings of the various bits of this field during a MRS operation.                                                                                                                                                                                                                                                                                 |
| 3:0  | RW   | 0x0         | cmd_opcode<br>Command to be issued to the memory.<br>4'b000 = Deselect. This is only used for timing purposes, no actual direct Deselect command is passed to the memories.<br>4'b0001 = Precharge All (PREA)<br>4'b0010 = Refresh (REF)<br>4'b0011 = Mode Register Set (MRS), MRS otherwise 4'b0100 = ZQ Calibration Short (ZQCS, only applies to DDR3)<br>4'b0101 = ZQ Calibration Long (ZQCL, only applies to DDR3)<br>4'b0110 = Software Driven Reset (RSTL, only applies to DDR3)<br>4'b0111 = Reserved<br>4'b1000 - Mode Register Read (MRR), is SRR in mDRR and is MPR in DDR3<br>Others - Reserved |

**DDR\_PCTL\_POWCTL**

Address: Operational Base + offset (0x0044)

Power Up Control Register

| Bit  | Attr   | Reset Value | Description                                                                                                                                                                                                                                                                                  |
|------|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1 | RO     | 0x0         | reserved                                                                                                                                                                                                                                                                                     |
| 0    | R/W SC | 0x0         | power_up_start<br>Start the memory power up sequence. When this bit is set to 1'b1, controller starts the CKE and RESET# power up sequence to the memories. This bit is automatically cleared by controller after the sequence is completed. This bit cannot be cleared to 1'b0 by software. |

**DDR\_PCTL\_POWSTAT**

Address: Operational Base + offset (0x0048)

Power Up Status Register

| Bit  | Attr | Reset Value | Description                                                                                                                                                              |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1 | RO   | 0x0         | reserved                                                                                                                                                                 |
| 0    | RO   | 0x0         | power_up_done<br>Returns the status of the memory power-up sequence.<br>1'b0 = Power-up sequence has not been performed.<br>1'b1 = Power-up sequence has been performed. |

**DDR\_PCTL\_CMDTSTAT**

Address: Operational Base + offset (0x004c)

## Command Timers Status Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x0                | reserved                                                                                                                                                                                                       |
| 0          | RO          | 0x0                | cmd_tstat<br>Returns the status of the timers for memory commands. This ANDs all the command timers together.<br>1'b0 = One or more command timers has not expired.<br>1'b1 = All command timers have expired. |

**DDR\_PCTL\_CMDTSTATEN**

Address: Operational Base + offset (0x0050)

Command Timers Status Enable Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x0                | reserved                                                                                                                                                                  |
| 0          | RW          | 0x0                | cmd_tstat_en<br>Enables the generation of the status of the timers for memory commands. Is enabled before CMDTSTAT register is read.<br>1'b0 - Disabled<br>1'b1 - Enabled |

**DDR\_PCTL\_MRRCFG0**

Address: Operational Base + offset (0x0060)

Mode Register Read Configuration 0

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------|
| 31:4       | RO          | 0x0                | reserved                                                                                                           |
| 3:0        | RW          | 0x0                | mrr_byte_sel<br>Selects which byte's data to store when performing an MRR command via MCMD.<br>LegalValues: 0 .. 8 |

**DDR\_PCTL\_MRRSTAT0**

Address: Operational Base + offset (0x0064)

Mode Register Read Status 0 Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                        |
|------------|-------------|--------------------|-------------------------------------------|
| 31:24      | RO          | 0x00               | mrrstat_beat3<br>MRR/MPR read data beat 3 |
| 23:16      | RO          | 0x00               | mrrstat_beat2<br>MRR/MPR read data beat 2 |
| 15:8       | RO          | 0x00               | mrrstat_beat1<br>MRR/MPR read data beat 1 |
| 7:0        | RO          | 0x00               | mrrstat_beat0<br>MRR/MPR read data beat 0 |

**DDR\_PCTL\_MRRSTAT1**

Address: Operational Base + offset (0x0068)

Mode Register Read Status 0 Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                        |
|------------|-------------|--------------------|-------------------------------------------|
| 31:24      | RO          | 0x00               | mrrstat_beat7<br>MRR/MPR read data beat 7 |
| 23:16      | RO          | 0x00               | mrrstat_beat6<br>MRR/MPR read data beat 6 |
| 15:8       | RO          | 0x00               | mrrstat_beat5<br>MRR/MPR read data beat 5 |
| 7:0        | RO          | 0x00               | mrrstat_beat4<br>MRR/MPR read data beat 4 |

**DDR\_PCTL\_MCFG1**

Address: Operational Base + offset (0x007c)

Memory Configuration 1 Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RW          | 0x0                | hw_exit_idle_en<br>When this bit is programmed to 1'b1 the c_active_in pin can be used to exit from the automatic clock stop, power down or self-refresh modes.                                                     |
| 30:24      | RO          | 0x0                | reserved                                                                                                                                                                                                            |
| 23:16      | RW          | 0x00               | hw_idle<br>Hardware idle period. The c_active output is driven high if the NIF is idle in Access state for hw_idle * 32 * n_clk cycles. The hardware idle function is disabled when hw_idle=0.                      |
| 15:8       | RO          | 0x0                | reserved                                                                                                                                                                                                            |
| 7:0        | RW          | 0x00               | sr_idle<br>Self-Refresh idle period. Memories are placed into Self-Refresh mode if the NIF is idle in Access state for sr_idle * 32 * n_clk cycles. The automatic self-refresh function is disabled when sr_idle=0. |

**DDR\_PCTL\_MCFG**

Address: Operational Base + offset (0x0080)

Memory Configuration Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                            |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20      | RW          | 0x0                | reserved                                                                                                                                                                                                                                      |
| 19:18      | RW          | 0x1                | tfaw_cfg<br>Field0000 Abstract<br>Sets tFAW to be 4, 5 or 6 times tRRD.<br>2'b00 = set tFAW=4*tRRD<br>2'b01 = set tFAW=5*tRRD<br>2'b10 = set tFAW=6*tRRD                                                                                      |
| 17         | RW          | 0x0                | pd_exit_mode<br>Selects the mode for Power Down Exit. For DDR3, the power down exit mode setting in controller must be consistent with the value programmed into the power down exit mode bit of MR0.<br>1'b0 = slow exit<br>1'b1 = fast exit |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16         | RW          | 0x0                | <p>pd_type<br/>Sets the Power down type.<br/>1'b0 = Precharge Power Down<br/>1'b1 = Active Power Down</p>                                                                                                                                                                                                                 |
| 15:8       | RW          | 0x00               | <p>pd_idle<br/>Power-down idle period in n_clk cycles. Memories are placed into power-down mode if the NIF is idle for pd_idle n_clk cycles. The automatic power down function is disabled when pd_idle=0.</p>                                                                                                            |
| 7:5        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                  |
| 4          | RW          | 0x0                | <p>stagger_cs<br/>For multi-rank commands from the DCU, stagger the assertion of CS_N to odd and even ranks by one n_clk cycle. This is useful when using RDIMMs, when multi-rank commands may be interpreted as writes to control words in the register chip.<br/>1'b0 = Do not stagger CS_N<br/>1'b1 = Stagger CS_N</p> |
| 3          | RW          | 0x0                | <p>two_t_en<br/>Enables 2T timing for memory commands.<br/>1'b0= Disabled<br/>1'b1 = Enabled</p>                                                                                                                                                                                                                          |
| 2:1        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                  |
| 0          | RW          | 0x0                | <p>mem_bl<br/>DDR Burst Length. The BL setting in DDR3 must be consistent with the value programmed into the BL field of MR0.<br/>1'b0 = BL4, Burst length of 4<br/>1'b1 = BL8, Burst length of 8 (MR0.BL=2'b00 for DDR3)</p>                                                                                             |

**DDR\_PCTL\_PPCFG**

Address: Operational Base + offset (0x0084)

Partially Populated Memories Configuration Register

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8:1        | RW          | 0x00               | <p>rpmem_dis<br/>Reduced Population Disable bits. Setting these bits disables the corresponding NIF/DDR data lanes from writing or reading data. Lane 0 is always present, hence only 8 bits are required for the remaining lanes including the ECC lane.</p> <p>In 1:2 mode bit 0 of rpmem_dis covers n_wdata/n_rdata/m_ctl_d/m_phy_q[63:32], bit 1 [95:64] etc.</p> <p>In 1:1 mode bit 0 of rpmem_dis covers n_wdata/n_rdata/m_ctl_d/m_phy_q[31:16], bit 2 [47:32] etc.</p> <p>There are no restrictions on which byte lanes can be disabled, other than byte lane 0 is required. Gaps between enabled byte lanes are allowed. For each bit:</p> <p>1'b0 = lane exists<br/>1'b1 = lane is disabled</p> |
| 0          | RW          | 0x0                | <p>ppmem_en<br/>Partially Population Enable bit. Setting this bit enables the partial population of external memories where the entire application bus is routed to a reduced size memory system. The lower half of the SDRAM data bus, bit 0 up to bit 15, is the active portion when Partially Populated memories are enabled.</p> <p>1'b0 = Disabled<br/>1'b1 = Enabled</p>                                                                                                                                                                                                                                                                                                                           |

**DDR\_PCTL\_MSTAT**

Address: Operational Base + offset (0x0088)

Memory Status Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                    |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3       | RO          | 0x0                | reserved                                                                                                                                                                                              |
| 2          | RO          | 0x0                | <p>self_refresh<br/>Indicates if controller, through auto self-refresh, has placed the memories in Self-Refresh.</p> <p>1'b0 = Memory is not in Self-Refresh<br/>1'b1 = Memory is in Self-Refresh</p> |
| 1          | RO          | 0x0                | <p>clock_stop<br/>Indicates if controller has placed the memories in Clock Stop.</p> <p>1'b0 = Memory is not in Clock Stop<br/>1'b1 = Memory is in Clock Stop</p>                                     |
| 0          | RO          | 0x0                | <p>power_down<br/>Indicates if controller has placed the memories in Power Down.</p> <p>1'b0 = Memory is not in Power Down<br/>1'b1 = Memory is in Power-Down</p>                                     |

**DDR\_PCTL\_DTUPDES**

Address: Operational Base + offset (0x0094)

DTU Status Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------|
| 31:14      | RO          | 0x0                | reserved                                                                                                                |
| 13         | RO          | 0x0                | dtu_rd_missing<br>Indicates if one or more read beats of data did not return from memory.                               |
| 12:9       | RO          | 0x0                | dtu_eaffl<br>Indicates the number of entries in the FIFO that is holding the log of error addresses for data comparison |
| 8          | RO          | 0x0                | dtu_random_error<br>Indicates that the random data generated had some failures when written and read to the memories    |
| 7          | RO          | 0x0                | dtu_err_b7<br>Detected at least 1 bit error for bit 7 in the programmable data buffers                                  |
| 6          | RO          | 0x0                | dtu_err_b6<br>Detected at least 1 bit error for bit 6 in the programmable data buffers                                  |
| 5          | RO          | 0x0                | dtu_err_b5<br>Detected at least 1 bit error for bit 5 in the programmable data buffers                                  |
| 4          | RO          | 0x0                | dtu_err_b4<br>Detected at least 1 bit error for bit 4 in the programmable data buffers                                  |
| 3          | RO          | 0x0                | dtu_err_b3<br>Detected at least 1 bit error for bit 3 in the programmable data buffers                                  |
| 2          | RO          | 0x0                | dtu_err_b2<br>Detected at least 1 bit error for bit 2 in the programmable data buffers                                  |
| 1          | RO          | 0x0                | dtu_err_b1<br>Detected at least 1 bit error for bit 1 in the programmable data buffers                                  |
| 0          | RO          | 0x0                | dtu_err_b0<br>Detected at least 1 bit error for bit 0 in the programmable data buffers                                  |

**DDR\_PCTL\_DTUNA**

Address: Operational Base + offset (0x0098)

DTU Number of Addresses Created Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | dtu_num_address<br>Indicates the number of addresses that were created on the NIF interface during random data generation. |

**DDR\_PCTL\_DTUNE**

Address: Operational Base + offset (0x009c)

## DTU Number of Errors Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | dtu_num_errors<br>Indicates the number of errors that were detected on the readback of the NIF data during random data generation. |

**DDR\_PCTL\_DTUPRD0**

Address: Operational Base + offset (0x00a0)

## DTU Parallel Read 0 Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | dtu_allbits_1<br>Allows all the bit ones from each of the 16 received read bytes to be read in parallel. Used as part of read data eye training where a transition is required to be monitored to train the eye.  |
| 15:0       | RO          | 0x0000             | dtu_allbits_0<br>Allows all the bit zeros from each of the 16 received read bytes to be read in parallel. Used as part of read data eye training where a transition is required to be monitored to train the eye. |

**DDR\_PCTL\_DTUPRD1**

Address: Operational Base + offset (0x00a4)

## DTU Parallel Read 1 Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | dtu_allbits_3<br>Allows all the bit threes from each of the 16 received read bytes to be read in parallel. Used as part of read data eye training where a transition is required to be monitored to train the eye. |
| 15:0       | RO          | 0x0000             | dtu_allbits_2<br>Allows all the bit twos from each of the 16 received read bytes to be read in parallel. Used as part of read data eye training where a transition is required to be monitored to train the eye.   |

**DDR\_PCTL\_DTUPRD2**

Address: Operational Base + offset (0x00a8)

## DTU Parallel Read 2 Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | dtu_allbits_5<br>Allows all the bit fives from each of the 16 received read bytes to be read in parallel. Used as part of read data eye training where a transition is required to be monitored to train the eye. |
| 15:0       | RO          | 0x0000             | dtu_allbits_4<br>Allows all the bit fours from each of the 16 received read bytes to be read in parallel. Used as part of read data eye training where a transition is required to be monitored to train the eye. |

**DDR\_PCTL\_DTUPRD3**

Address: Operational Base + offset (0x00ac)

DTU Parallel Read 3 Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | dtu_allbits_7<br>Allows all the bit sevens from each of the 16 received read bytes to be read in parallel. Used as part of read data eye training where a transition is required to be monitored to train the eye. |
| 15:0       | RO          | 0x0000             | dtu_allbits_6<br>Allows all the bit sixes from each of the 16 received read bytes to be read in parallel. Used as part of read data eye training where a transition is required to be monitored to train the eye.  |

**DDR\_PCTL\_DTUAWDT**

Address: Operational Base + offset (0x00b0)

DTU Address Width Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:11      | RO          | 0x0                | reserved                                                                                                                                                                         |
| 10:9       | RW          | 0x1                | number_ranks<br>Number of supported memory ranks.<br>2'b00 = 1 rank<br>2'b01 = 2 ranks                                                                                           |
| 8          | RO          | 0x0                | reserved                                                                                                                                                                         |
| 7:6        | RW          | 0x2                | row_addr_width<br>Width of the memory row address bits.<br>2'b00 = 13 bits wide<br>2'b01 = 14 bits wide<br>2'b10 = 15 bits wide<br>2'b11 = 16 bits wide                          |
| 5          | RO          | 0x0                | reserved                                                                                                                                                                         |
| 4:3        | RW          | 0x2                | bank_addr_width<br>Field0000 Abstract<br>Width of the memory bank address bits.<br>2'b00 = 2 bits wide (4 banks)<br>2'b01 = 3 bits wide (8 banks)<br>Others = Reserved           |
| 2          | RO          | 0x0                | reserved                                                                                                                                                                         |
| 1:0        | RW          | 0x0                | column_addr_width<br>Field0000 Abstract<br>Width of the memory column address bits.<br>2'b00 = 7 bits wide<br>2'b01 = 8 bits wide<br>2'b10 = 9 bits wide<br>2'b11 = 10 bits wide |

**DDR\_PCTL\_TOGCNT1U**

Address: Operational Base + offset (0x00c0)

## Toggle Counter 1us Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------|
| 31:10      | RO          | 0x0                | reserved                                                        |
| 9:0        | RW          | 0x064              | toggle_counter_1u<br>The number of internal timers clock cycles |

**DDR\_PCTL\_TINIT**

Address: Operational Base + offset (0x00c4)

t\_init Timing Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:9       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                         |
| 8:0        | RW          | 0x0c8              | t_init<br>Defines the time period (in us) to hold dfi_cke and dfi_reset_n stable during the memory power up sequence. The value programmed must correspond to at least 200us. The actual time period defined is TINIT * TOGCNT1U * internal timers clock .period |

**DDR\_PCTL\_TRSTH**

Address: Operational Base + offset (0x00c8)

t\_rsth Timing Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                   |
| 9:0        | RW          | 0x000              | t_rsth<br>Defines the time period (in us) to hold the dfi_reset_n signal high after it is de-asserted during the DDR3 Power Up/Reset sequence. The value programmed for DDR3 must correspond to minimum 500us of delay. The actual time period defined is TRSTH * TOGCNT1U * internal timers clock period. |

**DDR\_PCTL\_TOGCNT100N**

Address: Operational Base + offset (0x00cc)

Toggle Counter 100ns

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------|
| 31:7       | RO          | 0x0                | reserved                                                           |
| 6:0        | RW          | 0x01               | toggle_counter_100n<br>The number of internal timers clock cycles. |

**DDR\_PCTL\_TREFI**

Address: Operational Base + offset (0x00d0)

t\_refi Timing Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                               |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                                                                                                                                         |
| 7:0        | RW          | 0x01               | t_refi<br>Defines the time period (in 100ns units) of the Refresh interval. The actual time period defined is TREFI * TOGCNT100N * internal timers clock period. |

**DDR\_PCTL\_TMRD**

Address: Operational Base + offset (0x00d4)

t\_mrd Timing Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 31:3       | RO          | 0x0                | reserved                                                                                                                                |
| 2:0        | RW          | 0x1                | t_mrd<br>Mode Register Set command cycle time in memory clock cycles.<br>DDR3: Time from MRS to MRS command.<br>DDR3 Legal Values: 2..4 |

**DDR\_PCTL\_TRFC**

Address: Operational Base + offset (0x00d8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                     |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------|
| 31:9       | RO          | 0x0                | reserved                                                                                               |
| 8:0        | RW          | 0x001              | t_rfc<br>Refresh to Active/Refresh command time in memory clock cycles.<br>DDR3 Legal Values: 36.. 374 |

**DDR\_PCTL\_TRP**

Address: Operational Base + offset (0x00dc)

t\_trp Timing Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:18      | RO          | 0x0                | reserved                                                                                                                                            |
| 17:16      | RW          | 0x1                | prea_extra<br>Additional cycles required for a Precharge All (PREA) command - in addition to t_rp. In terms of memory clock cycles<br>DDR3 Value: 0 |
| 15:4       | RO          | 0x0                | reserved                                                                                                                                            |
| 3:0        | RW          | 0x6                | t_rp<br>Precharge period in memory clock cycles.<br>DDR3 Legal Values: 5..14                                                                        |

**DDR\_PCTL\_TRTW**

Address: Operational Base + offset (0x00e0)

t\_rtw Timing Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------|
| 31:4       | RO          | 0x0                | reserved                                                                                   |
| 3:0        | RW          | 0x2                | t_rtw<br>Read to Write turnaround time in memory clock cycles.<br>DDR3 Legal Values: 2..10 |

**DDR\_PCTL\_TAL**

Address: Operational Base + offset (0x00e4)

AL Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                |
| 3:0        | RW          | 0x0                | t_al<br>Additive Latency in memory clock cycles.<br>For DDR3 this must be 0, CL-1, CL-2 depending weather the AL value in MR1 is 0, 1, or 2 respectively. CL is the CAS latency programmed into MR0.<br>DDR3 Legal Values: 0, CL-1, CL-2 (depending on AL=0,1,2 in MR1) |

**DDR\_PCTL\_TCL**

Address: Operational Base + offset (0x00e8)

CL Timing Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4       | RO          | 0x0                | reserved                                                                                                                                                |
| 3:0        | RW          | 0x4                | t_cl<br>CAS Latency in memory clock cycles.<br>The controller setting must match the value programmed into the CL field of MR0.<br>DDR3 Legal Value: CL |

**DDR\_PCTL\_TCWL**

Address: Operational Base + offset (0x00ec)

CWL Timing Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4       | RO          | 0x0                | reserved                                                                                                                                                             |
| 3:0        | RW          | 0x3                | t_cwl<br>CAS Write Latency in memory clock cycles.<br>For DDR3, the setting must match the value programmed in the memory CWL field of MR2.<br>DDR3 Legal Value: CWL |

**DDR\_PCTL\_TRAS**

Address: Operational Base + offset (0x00f0)

t\_ras Timing Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                               |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------|
| 31:6       | RO          | 0x0                | reserved                                                                                         |
| 5:0        | RW          | 0x10               | t_ras<br>Activate to Precharge command time in memory clock cycles.<br>DDR3 Legal Values: 15..38 |

**DDR\_PCTL\_TRC**

Address: Operational Base + offset (0x00f4)

t\_rc Timing Register

| <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          | 0x16               | t_rc<br>Row Cycle time in memory clock cycles. Specifies the minimum Activate to Activate distance for accesses to same bank.<br>DDR3 Legal Values: 20..52 |

**DDR\_PCTL\_TRCD**

Address: Operational Base + offset (0x00f8)

t\_rcd Timing Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| 31:4       | RO          | 0x0                | reserved                                                                                                                            |
| 3:0        | RW          | 0x6                | t_rcd<br>Row to Column delay in memory clock cycles. Specifies the minimum Activate to Column distance.<br>DDR3 Legal Values: 5..14 |

**DDR\_PCTL\_TRRD**

Address: Operational Base + offset (0x00fc)

t\_rrd Timing Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                             |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4       | RO          | 0x0                | reserved                                                                                                                                                                                       |
| 3:0        | RW          | 0x4                | t_rrd<br>Row-to-Row delay in memory clock cycles. Specifies the minimum Activate-to-Activate distance for consecutive accesses to different banks in the same rank.<br>DDR3 Legal Values: 4..8 |

**DDR\_PCTL\_TRTP**

Address: Operational Base + offset (0x0100)

t\_rtp Timing Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4       | RO          | 0x0                | reserved                                                                                                                                                                   |
| 3:0        | RW          | 0x3                | t_rtp<br>Read to Precharge time in memory clock cycles. Specifies the minimum distance Read to Precharge for consecutive accesses to same bank.<br>DDR3 Legal Values: 3..8 |

**DDR\_PCTL\_TWR**

Address: Operational Base + offset (0x0104)

t\_wr Register

| <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          | 0x06               | t_wr<br>Write recovery time in memory clock cycles. When using close page the controller setting must be consistent with the WR field setting of MRO.<br>DDR3 Legal Values: 6..16 |

**DDR\_PCTL\_TWTR**

Address: Operational Base + offset (0x0108)

t\_wtr Timing Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------|
| 31:4       | RO          | 0x0                | reserved                                                                                   |
| 3:0        | RW          | 0x4                | t_wtr<br>Write to Read turnaround time, in memory clock cycles.<br>DDR3 Legal Values: 3..8 |

**DDR\_PCTL\_TEXSR**

Address: Operational Base + offset (0x010c)

t\_exsr Timing Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                   |
| 9:0        | RW          | 0x001              | t_exsr<br>Exit Self-Refresh to first valid command delay, in memory clock cycles.<br>For DDR3, this should be programmed to match tXSDLL (SRE to a command requiring DLL locked) as defined by the memory device specification.<br>DDR3 Typical Value: 512 |

**DDR\_PCTL\_TXP**

Address: Operational Base + offset (0x0110)

t\_xp Timing Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------|
| 31:3       | RO          | 0x0                | reserved                                                                                                                             |
| 2:0        | RW          | 0x1                | t_xp<br>Exit Power Down to first valid command delay when DLL is on (fast exit), measured in memory clock cycles. Legal Values: 1..7 |

**DDR\_PCTL\_TXPDLL**

Address: Operational Base + offset (0x0114)

t\_xpdll Timing Register

| <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               | t_xpdll<br>Exit Power Down to first valid command delay when DLL is off (slow exit), measured in memory clock cycles.<br>DDR3 Legal Values: 3..63 |

**DDR\_PCTL\_TZQCS**

Address: Operational Base + offset (0x0118)

t\_zqcs Timing Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                             |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:7       | RO          | 0x0                | reserved                                                                                                                                                                                       |
| 6:0        | RW          | 0x00               | t_zqcs<br>SDRAM ZQ Calibration Short period, in memory clock cycles.<br>Should be programmed to match the tZQCS timing value as defined in the memory specification.<br>DDR3 Typical Value: 64 |

**DDR\_PCTL\_TZQCSI**

Address: Operational Base + offset (0x011c)

t\_zqcsi Timing Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | t_zqcsi<br>SDRAM ZQCS interval, measured in Refresh interval units. The total time period defined is TZQCSI * TREFI * TOGCNT100N * internal timers clock period. Programming a value of 0 in t_zqcsi disables the auto-ZQCS functionality in controller.<br>DDR3 Legal Values: 0..4294967295 |

**DDR\_PCTL\_TDQS**

Address: Operational Base + offset (0x0120)

t\_dqs Timing Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                               |
| 2:0        | RW          | 0x1                | t_dqs<br>Additional data turnaround time in memory clock cycles for accesses to different ranks. Used to increase the distance between column commands to different ranks, allowing more tolerance as the driver source changes on the bidirectional DQS and/or DQ signals.<br>DDR3 Legal Values: 1..7 |

**DDR\_PCTL\_TCKSRE**

Address: Operational Base + offset (0x0124)

t\_cksre Timing Register

| <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               | t_cksrc<br>In DDR3, this is the time after Self-Refresh Entry that CKE is held high before going low. In memory clock cycles. Specifies the clock disable delay after SRE. This should be programmed to match the greatest value between 10ns and 5 memory clock periods.<br>DDR3 Legal Values: 5..15 |

**DDR\_PCTL\_TCKSRX**

Address: Operational Base + offset (0x0128)

t\_cksrc Timing Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                       |
| 4:0        | RW          | 0x00               | t_cksrc<br>In DDR3, this is the time (before Self-Refresh Exit) that CKE is maintained high before issuing SRX. In memory clock cycles. Specifies the clock stable time before SRX. This should be programmed to match the greatest value between 10ns and 5 memory clock periods.<br>DDR3 Legal Values: 5..15 |

**DDR\_PCTL\_TCKE**

Address: Operational Base + offset (0x012c)

t\_cke Timing Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------|
| 31:3       | RO          | 0x0                | reserved                                                                            |
| 2:0        | RW          | 0x3                | t_cke<br>CKE minimum pulse width in memory clock cycles.<br>DDR3 Legal Values: 3..6 |

**DDR\_PCTL\_TMOD**

Address: Operational Base + offset (0x0130)

t\_mod Timing Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x0                | reserved                                                                                                                                                   |
| 4:0        | RW          | 0x00               | t_mod<br>In DDR3 mode, this is the time from MRS to any valid non-MRS command (except DESELECT or NOP) in memory clock cycles.<br>DDR3 Legal Values: 0..31 |

**DDR\_PCTL\_TRSTL**

Address: Operational Base + offset (0x0134)

Reset Low Timing Register

| <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          | 0x00               | t_rstl<br>Memory Reset Low time, in memory clock cycles. Defines the time period to hold dfi_reset_n signal low during a software driven DDR3 Reset Operation. The value programmed must correspond to at least 100ns of delay.<br>DDR3 Legal Values: 1..127 |

**DDR\_PCTL\_TZQCL**

Address: Operational Base + offset (0x0138)

t\_zqcl Timing Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                            |
| 9:0        | RW          | 0x000              | t_zqcl<br>SDRAM ZQ Calibration Long period in memory clock cycles. If DDR3, should be programmed to match the memory tZQinit timing value for the first ZQCL command during memory initialization; should be programmed to match tZQoper timing value after reset and initialization.<br>DDR3 Legal Values: 0..1023 |

**DDR\_PCTL\_TMRR**

Address: Operational Base + offset (0x013c)

t\_mrr Timing Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                                        |
| 7:0        | RW          | 0x02               | t_mrr<br>Time for a Mode Register Read (MRR command from MCMD). |

**DDR\_PCTL\_TCKESR**

Address: Operational Base + offset (0x0140)

t\_ckesr Timing Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4       | RO          | 0x0                | reserved                                                                                                                                                                          |
| 3:0        | RW          | 0x4                | t_ckesr<br>Minimum CKE low width for Self-Refresh entry to exit timing in memory clock cycles. Recommended settings:<br>For DDR3 : t_ckesr = t_cke + 1<br>DDR3 Legal Values: 4..7 |

**DDR\_PCTL\_TDPPD**

Address: Operational Base + offset (0x0144)

t\_dpd Timing Register

| <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:0        | RW          | 0x000              | t_dpd<br>Minimum Deep Power Down time. Is in terms of us. When a MCMD.DPDE command occurs, TDPD time is waited before MCMD.start_cmd can be cleared. MCMD_cmd_add_del (if any) does not start until TDPD has completed. This ensures TDPD requirement for the memory is not violated. The actual time period defined is TDPD* TOGCNT1U * internal timers clock period.<br>DDR3 Legal Values: 0 |

**DDR\_PCTL\_DTUWACTL**

Address: Operational Base + offset (0x0200)

DTU Write Address Control

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                          |
|------------|-------------|--------------------|-------------------------------------------------------------|
| 31:30      | RW          | 0x0                | dtu_wr_rank<br>Write rank to where data is to be targeted   |
| 29         | RO          | 0x0                | reserved                                                    |
| 28:13      | RW          | 0x0000             | dtu_wr_row<br>Write row to where data is to be targeted     |
| 12:10      | RW          | 0x0                | dtu_wr_bank<br>Write bank to where data is to be targeted   |
| 9:0        | RW          | 0x000              | dtu_wr_col<br>FWrite column to where data is to be targeted |

**DDR\_PCTL\_DTURACTL**

Address: Operational Base + offset (0x0204)

DTU Read Address Control Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                              |
|------------|-------------|--------------------|-------------------------------------------------|
| 31:30      | RW          | 0x0                | dtu_rd_rank<br>Read rank from where data comes  |
| 29         | RO          | 0x0                | reserved                                        |
| 28:13      | RW          | 0x0000             | dtu_rd_row<br>Read row from where data comes    |
| 12:10      | RW          | 0x0                | dtu_rd_bank<br>Read bank from where data comes  |
| 9:0        | RW          | 0x000              | dtu_rd_col<br>Read column from where data comes |

**DDR\_PCTL\_DTUCFG**

Address: Operational Base + offset (0x0208)

DTU Configuration Control Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------|
| 31:23      | RO          | 0x0                | reserved                                                                                                                      |
| 22:16      | RW          | 0x00               | dtu_row_increments<br>Number of times to increment the row address when generating random data, up to a maximum of 127 times. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15         | RW          | 0x0                | dtu_wr_multi_rd<br>When set puts the DTU into write once multiple reads mode.                                                                                                 |
| 14         | RW          | 0x0                | dtu_data_mask_en<br>Controls whether random generated data masks are transmitted.<br>Unless enabled all data bytes are written to memory and expected to be read from memory. |
| 13:10      | RW          | 0x0                | dtu_target_lane<br>Selects one of the byte lanes for data comparison into the programmable read data buffer.                                                                  |
| 9          | RW          | 0x0                | dtu_generate_random<br>Generate transfers using random data, otherwise generate transfers from the programmable write data buffers.                                           |
| 8          | RW          | 0x0                | dtu_incr_banks<br>When the column address rolls over increment the bank address until we reach and conclude bank 7.                                                           |
| 7          | RW          | 0x0                | dtu_incr_cols<br>Increment the column address until we saturate. Return to zero if DTUCFG.dtu_incr_banks is set to 1 and we are not at bank 7.                                |
| 6:1        | RW          | 0x00               | dtu_nalen<br>Length of the NIF transfer sequence that is passed through the controller for each created address.                                                              |
| 0          | RW          | 0x0                | dtu_enable<br>When set, allows the DTU module to take ownership of the NIF interface:<br>1: DTU enabled<br>0: DTU disabled                                                    |

**DDR\_PCTL\_DTUectl**

Address: Operational Base + offset (0x020c)

DTU Execute Control Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3       | RO          | 0x0                | reserved                                                                                                                                                                                                          |
| 2          | R/W SC      | 0x0                | wr_multi_rd_RST<br>When set, resets the DTU in write once multiple reads mode, to allow a new write to be performed. This bit automatically clears.                                                               |
| 1          | R/W SC      | 0x0                | run_error_reports<br>When set, initiates the calculation of the error status bits. This bit automatically clears when the re-calculation is done. This is only used in debug mode to verify the comparison logic. |
| 0          | R/W SC      | 0x0                | run_dtu<br>When set, initiates the running of the DTU read and write transfer. This bit automatically clears when the transfers are completed                                                                     |

**DDR\_PCTL\_DTUwdo**

Address: Operational Base + offset (0x0210)

## DTU Write Data #0 Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>              |
|------------|-------------|--------------------|---------------------------------|
| 31:24      | RW          | 0x00               | dtu_wr_byte3<br>Write data byte |
| 23:16      | RW          | 0x00               | dtu_wr_byte2<br>Write data byte |
| 15:8       | RW          | 0x00               | dtu_wr_byte1<br>Write data byte |
| 7:0        | RW          | 0x00               | dtu_wr_byte0<br>Write data byte |

**DDR\_PCTL\_DTUWD1**

Address: Operational Base + offset (0x0214)

## DTU Write Data #1 Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>              |
|------------|-------------|--------------------|---------------------------------|
| 31:24      | RW          | 0x00               | dtu_wr_byte7<br>Write data byte |
| 23:16      | RW          | 0x00               | dtu_wr_byte6<br>Write data byte |
| 15:8       | RW          | 0x00               | dtu_wr_byte5<br>Write data byte |
| 7:0        | RW          | 0x00               | dtu_wr_byte4<br>Write data byte |

**DDR\_PCTL\_DTUWD2**

Address: Operational Base + offset (0x0218)

## DTU Write Data #2 Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>               |
|------------|-------------|--------------------|----------------------------------|
| 31:24      | RW          | 0x00               | dtu_wr_byte11<br>Write data byte |
| 23:16      | RW          | 0x00               | dtu_wr_byte10<br>Write data byte |
| 15:8       | RW          | 0x00               | dtu_wr_byte9<br>Write data byte  |
| 7:0        | RW          | 0x00               | dtu_wr_byte8<br>Write data byte  |

**DDR\_PCTL\_DTUWD3**

Address: Operational Base + offset (0x021c)

## DTU Write Data #3 Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>               |
|------------|-------------|--------------------|----------------------------------|
| 31:24      | RW          | 0x00               | dtu_wr_byte15<br>Write data byte |
| 23:16      | RW          | 0x00               | dtu_wr_byte14<br>Write data byte |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>               |
|------------|-------------|--------------------|----------------------------------|
| 15:8       | RW          | 0x00               | dtu_wr_byte13<br>Write data byte |
| 7:0        | RW          | 0x00               | dtu_wr_byte12<br>Write data byte |

**DDR\_PCTL\_DTUWDM**

Address: Operational Base + offset (0x0220)

DTU Write Data Mask Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0                | reserved                                                                                                                        |
| 15:0       | RW          | 0x0000             | dm_wr_byte0<br>Write data mask bit, one bit for each byte. Each bit should be 0 for a byte lane that contains valid write data. |

**DDR\_PCTL\_DTURDO**

Address: Operational Base + offset (0x0224)

DTU Read Data #0 Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>        |
|------------|-------------|--------------------|---------------------------|
| 31:24      | RO          | 0x00               | dtu_rd_byte3<br>Read byte |
| 23:16      | RO          | 0x00               | dtu_rd_byte2<br>Read byte |
| 15:8       | RO          | 0x00               | dtu_rd_byte1<br>Read byte |
| 7:0        | RO          | 0x00               | dtu_rd_byte0<br>Read byte |

**DDR\_PCTL\_DTURD1**

Address: Operational Base + offset (0x0228)

DTU Read Data #1 Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>        |
|------------|-------------|--------------------|---------------------------|
| 31:24      | RO          | 0x00               | dtu_rd_byte7<br>Read byte |
| 23:16      | RO          | 0x00               | dtu_rd_byte6<br>Read byte |
| 15:8       | RO          | 0x00               | dtu_rd_byte5<br>Read byte |
| 7:0        | RO          | 0x00               | dtu_rd_byte4<br>Read byte |

**DDR\_PCTL\_DTURD2**

Address: Operational Base + offset (0x022c)

DTU Read Data #2 Register

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>         |
|------------|-------------|--------------------|----------------------------|
| 31:24      | RO          | 0x00               | dtu_rd_byte11<br>Read byte |
| 23:16      | RO          | 0x00               | dtu_rd_byte10<br>Read byte |
| 15:8       | RO          | 0x00               | dtu_rd_byte9<br>Read byte  |
| 7:0        | RO          | 0x00               | dtu_rd_byte8<br>Read byte  |

**DDR\_PCTL\_DTURD3**

Address: Operational Base + offset (0x0230)

DTU Read Data #3 Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>         |
|------------|-------------|--------------------|----------------------------|
| 31:24      | RO          | 0x00               | dtu_rd_byte15<br>Read byte |
| 23:16      | RO          | 0x00               | dtu_rd_byte14<br>Read byte |
| 15:8       | RO          | 0x00               | dtu_rd_byte13<br>Read byte |
| 7:0        | RO          | 0x00               | dtu_rd_byte12<br>Read byte |

**DDR\_PCTL\_DTULFSRWD**

Address: Operational Base + offset (0x0234)

DTU LFSR Seed for Write Data Generation Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | dtu_lfsr_wseed<br>This is the initial seed for the random write data generation LFSR (linear feedback shift register), shared with the write mask generation. |

**DDR\_PCTL\_DTULFSRRD**

Address: Operational Base + offset (0x0238)

DTU LFSR Seed for Read Data Generation Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | dtu_lfsr_rseed<br>This is the initial seed for the random read data generation LFSR (linear feedback shift register), this is shared with the read mask generation. The read data mask is reconstructed the same as the write data mask was created, allowing the "on the fly comparison" ignore bytes which were not written. |

**DDR\_PCTL\_DTUEAF**

Address: Operational Base + offset (0x023c)

DTU Error Address FIFO Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30      | RO          | 0x0                | ea_rank<br>Indicates the rank that the error occurred in during random data generation. There could be a number of entries in this FIFO. If FIFO is empty one reads zeroes.             |
| 29         | RO          | 0x0                | reserved                                                                                                                                                                                |
| 28:13      | RO          | 0x0000             | ea_row<br>Indicates the row that the error occurred in during random data generation. There could be a number of entries in this FIFO. If FIFO is empty one reads zeroes.               |
| 12:10      | RO          | 0x0                | ea_bank<br>Indicates the bank that the error occurred in during random data generation. There could be a number of entries in this FIFO. If FIFO is empty one reads zeroes              |
| 9:0        | RO          | 0x000              | ea_column<br>Indicates the column address that the error occurred in during random data generation. There could be a number of entries in this FIFO. If FIFO is empty one reads zeroes. |

**DDR\_PCTL\_DFITCTRLDELAY**

Address: Operational Base + offset (0x0240)

DFI tctrl\_delay Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                          |
| 3:0        | RW          | 0x2                | tctrl_delay<br>Specifies the number of DFI clock cycles after an assertion or deassertion of the DFI control signals that the control signals at the PHY-DRAM interface reflect the assertion or de-assertion. If the DFI clock and the memory clock are not phase-aligned, this timing parameter should be rounded up to the next integer value. |

**DDR\_PCTL\_DFIODTCFG**

Address: Operational Base + offset (0x0244)

DFI ODT Configuration

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                        |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------|
| 31:13      | RO          | 0x0                | reserved                                                                                                  |
| 12         | RW          | 0x0                | rank1_odt_default<br>Default ODT value of rank 1 when there is no read/write activity                     |
| 11         | RW          | 0x0                | rank1_odt_write_sel<br>Enable/disable ODT for rank 1 when a write access is occurring on this rank        |
| 10         | RW          | 0x0                | rank1_odt_write_nse<br>Enable/disable ODT for rank 1 when a write access is occurring on a different rank |

| Bit | Attr | Reset Value | Description                                                                                                |
|-----|------|-------------|------------------------------------------------------------------------------------------------------------|
| 9   | RW   | 0x0         | rank1_odt_read_sel<br>Enable/disable ODT for rank 1 when a read access is occurring on this rank           |
| 8   | RW   | 0x0         | rank1_odt_read_nsel<br>Enable/disable ODT for rank 1 when a read access is occurring on a different rank   |
| 7:5 | RO   | 0x0         | reserved                                                                                                   |
| 4   | RW   | 0x0         | rank0_odt_default<br>Default ODT value of rank 0 when there is no read/write activity                      |
| 3   | RW   | 0x0         | rank0_odt_write_sel<br>Enable/disable ODT for rank 0 when a write access is occurring on this rank         |
| 2   | RW   | 0x0         | rank0_odt_write_nsel<br>Enable/disable ODT for rank 0 when a write access is occurring on a different rank |
| 1   | RW   | 0x0         | rank0_odt_read_sel<br>Enable/disable ODT for rank 0 when a read access is occurring on this rank           |
| 0   | RW   | 0x0         | rank0_odt_read_nsel<br>Enable/disable ODT for rank 0 when a read access is occurring on a different rank   |

**DDR\_PCTL\_DFIODTCFG1**

Address: Operational Base + offset (0x0248)

DFI ODT Timing Configuration 1 (for Latency and Length)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                             |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:27 | RO   | 0x0         | reserved                                                                                                                                                                                                                                |
| 26:24 | RW   | 0x6         | odt_len_bl8_r<br>ODT length for BL8 read transfers Length of dfi_odt signal for BL8 reads. This is in terms of SDR cycles. For BL4 reads, the length of dfi_odt is always 2 cycles shorter than the value in this register field.       |
| 23:19 | RO   | 0x0         | reserved                                                                                                                                                                                                                                |
| 18:16 | RW   | 0x6         | odt_len_bl8_w<br>ODT length for BL8 write transfers Length of dfi_odt signal for BL8 writes. This is in terms of SDR cycles.<br>For BL4 writes, the length of dfi_odt is always 2 cycles shorter than the value in this register field. |
| 15:13 | RO   | 0x0         | reserved                                                                                                                                                                                                                                |
| 12:8  | RW   | 0x00        | odt_lat_r<br>Field0000 Abstract<br>ODT latency for reads Latency after a read command that dfi_odt is set. This is in terms of SDR cycles.                                                                                              |
| 7:5   | RO   | 0x0         | reserved                                                                                                                                                                                                                                |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------|
| 4:0        | RW          | 0x00               | odt_lat_w<br>ODT latency for writes Latency after a write command that dfi_odt is set. This is in terms of SDR cycles |

**DDR\_PCTL\_DFIODTRANKMAP**

Address: Operational Base + offset (0x024c)

DFI ODT Rank Mapping

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6       | RO          | 0x0                | reserved                                                                                                                                                                                                                                     |
| 5:4        | RW          | 0x2                | odt_rank_map1<br>Rank mapping for dfi_odt[1] Determines which rank access(es) will cause dfi_odt[1] to be asserted<br>Bit 5= 1: dfi_odt[1] will be asserted to terminate rank 1<br>Bit 4= 1: dfi_odt[1] will be asserted to terminate rank 0 |
| 3:2        | RO          | 0x4                | reserved                                                                                                                                                                                                                                     |
| 1:0        | RW          | 0x1                | odt_rank_map0<br>Rank mapping for dfi_odt[0] Determines which rank access(es) will cause dfi_odt[0] to be asserted<br>Bit 1= 1: dfi_odt[0] will be asserted to terminate rank 1<br>Bit 0= 1: dfi_odt[0] will be asserted to terminate rank 0 |

**DDR\_PCTL\_DFITPHYWRDATA**

Address: Operational Base + offset (0x0250)

DFI tphy\_wrdata Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                            |
| 5:0        | RW          | 0x01               | tphy_wrdata<br>Specifies the number of DFI clock cycles between when the dfi_wrdata_en signal is asserted to when the associated write data is driven on the dfi_wrdata signal. This has no impact on performance, only adjusts the relative time between enable and data transfer. |

**DDR\_PCTL\_DFITPHYWRLAT**

Address: Operational Base + offset (0x0254)

DFI tphy\_wrlat Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6       | RO          | 0x0                | reserved                                                                                                                                                                |
| 5:0        | RW          | 0x01               | tphy_wrlat<br>Specifies the number of DFI clock cycles between when a write command is sent on the DFI control interface and when the dfi_wrdata_en signal is asserted. |

**DDR\_PCTL\_DFITRDDATAEN**

Address: Operational Base + offset (0x0260)

## DFI trddata\_en Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6       | RO          | 0x0                | reserved                                                                                                                                             |
| 5:0        | RW          | 0x01               | trddata_en<br>Specifies the number of DFI clock cycles from the assertion of a read command on the DFI to the assertion of the dfi_rddata_en signal. |

**DDR\_PCTL\_DFITPHYRDLAT**

Address: Operational Base + offset (0x0264)

## DFI tphy\_rdlat Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6       | RO          | 0x0                | reserved                                                                                                                                                               |
| 5:0        | RW          | 0x0f               | tphy_rdlat<br>Specifies the maximum number of DFI clock cycles allowed from the assertion of the dfi_rddata_en signal to the assertion of the dfi_rddata_valid signal. |

**DDR\_PCTL\_DFITPHYUPDTYPE0**

Address: Operational Base + offset (0x0270)

## DFI tphyupd\_type0 Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:12      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                |
| 11:0       | RW          | 0x010              | tphyupd_type0<br>Specifies the maximum number of DFI clock cycles that the dfi_phyupd_req signal may remain asserted after the assertion of the dfi_phyupd_ack signal for dfi_phyupd_type = 0x0. The dfi_phyupd_req signal may de-assert at any cycle after the assertion of the dfi_phyupd_ack signal. |

**DDR\_PCTL\_DFITPHYUPDTYPE1**

Address: Operational Base + offset (0x0274)

## DFI tphyupd\_type1 Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:12      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                |
| 11:0       | RW          | 0x010              | tphyupd_type1<br>Specifies the maximum number of DFI clock cycles that the dfi_phyupd_req signal may remain asserted after the assertion of the dfi_phyupd_ack signal for dfi_phyupd_type = 0x1. The dfi_phyupd_req signal may de-assert at any cycle after the assertion of the dfi_phyupd_ack signal. |

**DDR\_PCTL\_DFITPHYUPDTYPE2**

Address: Operational Base + offset (0x0278)

## DFI tphyupd\_type2 Register

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:12      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                |
| 11:0       | RW          | 0x010              | tphyupd_type2<br>Specifies the maximum number of DFI clock cycles that the dfi_phyupd_req signal may remain asserted after the assertion of the dfi_phyupd_ack signal for dfi_phyupd_type = 0x2. The dfi_phyupd_req signal may de-assert at any cycle after the assertion of the dfi_phyupd_ack signal. |

**DDR\_PCTL\_DFITPHYUPDTYPE3**

Address: Operational Base + offset (0x027c)

DFI tphyupd\_type3 Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:12      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                |
| 11:0       | RW          | 0x010              | tphyupd_type3<br>Specifies the maximum number of DFI clock cycles that the dfi_phyupd_req signal may remain asserted after the assertion of the dfi_phyupd_ack signal for dfi_phyupd_type = 0x3. The dfi_phyupd_req signal may de-assert at any cycle after the assertion of the dfi_phyupd_ack signal. |

**DDR\_PCTL\_DFITCTRLUPDMIN**

Address: Operational Base + offset (0x0280)

DFI tctrlupd\_min Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0                | reserved                                                                                                           |
| 15:0       | RW          | 0x0010             | tctrlupd_min<br>Specifies the minimum number of DFI clock cycles that the dfi_ctrlupd_req signal must be asserted. |

**DDR\_PCTL\_DFITCTRLUPDMAX**

Address: Operational Base + offset (0x0284)

DFI tctrlupd\_max Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0                | reserved                                                                                                     |
| 15:0       | RW          | 0x0040             | tctrlupd_max<br>Specifies the maximum number of DFI clock cycles that the dfi_ctrlupd_req signal can assert. |

**DDR\_PCTL\_DFITCTRLUPDDLY**

Address: Operational Base + offset (0x0288)

DFI tctrlupddly Register

| <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          | 0x8                | tctrlupd_dly<br>Delay in DFI clock cycles between time a controller-initiated update could be started and time controller-initiated update actually starts (dfi_ctrlupd_req going high). |

**DDR\_PCTL\_DFIUPDCFG**

Address: Operational Base + offset (0x0290)

DFI Update Configuration Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------|
| 31:2       | RO          | 0x0                | reserved                                                                                                           |
| 1          | RW          | 0x1                | dfi_phyupd_en<br>Enables the support for acknowledging PHY-initiated updates:<br>1'b0 = Disabled<br>1'b1 = Enabled |
| 0          | RW          | 0x1                | dfi_ctrlupd_en<br>Enables the generation of controller-initiated updates:<br>1'b0 = Disabled<br>1'b1 = Enabled     |

**DDR\_PCTL\_DFITREFMSKI**

Address: Operational Base + offset (0x0294)

DFI Masked Refresh Interval

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                |
| 7:0        | RW          | 0x00               | trefmski<br>Time period of the masked Refresh interval This value is only used if TREFI==0. Defines the time period (in 100ns units) of the masked Refresh (REFMSK) interval. The actual time period defined is DFITREFMSKI* TOGCNT100N * internal timers clock period. |

**DDR\_PCTL\_DFITCTRLUPDI**

Address: Operational Base + offset (0x0298)

DFI tctrlupd\_interval Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | tctrlupd_interval<br>DFI controller-initiated updates interval, measured in terms of Refresh interval units.<br>If TREFI!=0, the time period is defined as DFITCTRLUPDI*TREFI * TOGCNT100N * internal timers clock period. If TREFI==0 and DFITREFMSKI!=0, the period changes to DFITCTRLUPDI * DFITREFMSKI * TOGCNT100N * internal timers clock period.<br>Programming a value of 0 is the same as programming a value of 1; for instance, a controller-initiated update occurs every Refresh interval. |

**DDR\_PCTL\_DFITRCFG0**

Address: Operational Base + offset (0x02ac)

DFI Training Configuration 0 Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20      | RO          | 0x0                | reserved                                                                                                                                                             |
| 19:16      | RW          | 0x0                | dfi_wrlvl_rank_sel<br>Determines the value to drive on the output signal dfi_wrlvl_cs_n.<br>The value on dfi_wrlvl_cs_n is the inverse of the setting in this field. |
| 15:13      | RO          | 0x0                | reserved                                                                                                                                                             |
| 12:4       | RW          | 0x000              | dfi_rdlvl_edge<br>Determines the value to drive on the output signal dfi_rdlvl_edge.<br>The value on dfi_rdlvl_edge is the same as the setting in this field.        |
| 3:0        | RW          | 0x0                | dfi_rdlvl_rank_sel<br>Determines the value to drive on the output signal dfi_rdlvl_cs_n.<br>The value on dfi_rdlvl_cs_n is the inverse of the setting in this field. |

**DDR\_PCTL\_DFITRSTAT0**

Address: Operational Base + offset (0x02b0)

DFI Training Status 0 Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------|
| 31:18      | RO          | 0x0                | reserved                                                                          |
| 17:16      | RO          | 0x0                | dfi_wrlvl_mode<br>Reports the value of the input signal dfi_wrlvl_mode.           |
| 15:10      | RO          | 0x0                | reserved                                                                          |
| 9:8        | RO          | 0x0                | dfi_rdlvl_gate_mode<br>Reports the value of the input signal dfi_rdlvl_gate_mode. |
| 7:2        | RO          | 0x0                | reserved                                                                          |
| 1:0        | RO          | 0x0                | dfi_rdlvl_mode<br>Reports the value of the input signal dfi_rdlvl_mode.           |

**DDR\_PCTL\_DFITRWRLVLEN**

Address: Operational Base + offset (0x02b4)

DFI Training dfi\_wrlvl\_en Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------|
| 31:9       | RO          | 0x0                | reserved                                                                         |
| 8:0        | RW          | 0x000              | dfi_wrlvl_en<br>Determines the value to drive on the output signal dfi_wrlvl_en. |

**DDR\_PCTL\_DFITRRDLVLEN**

Address: Operational Base + offset (0x02b8)

DFI Training dfi\_rdlvl\_en Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------|
| 31:9       | RO          | 0x0                | reserved                                                                         |
| 8:0        | RW          | 0x000              | dfi_rdlvl_en<br>Determines the value to drive on the output signal dfi_rdlvl_en. |

**DDR\_PCTL\_DFITRRDLVLGATEEN**

Address: Operational Base + offset (0x02bc)

DFI Training dfi\_rdlvl\_gate\_en Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------|
| 31:9       | RO          | 0x0                | reserved                                                                                   |
| 8:0        | RW          | 0x000              | dfi_rdlvl_gate_en<br>Determines the value to drive on the output signal dfi_rdlvl_gate_en. |

**DDR\_PCTL\_DFISTSTAT0**

Address: Operational Base + offset (0x02c0)

DFI Status Status 0 Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------|
| 31:25      | RO          | 0x0                | reserved                                                                               |
| 24:16      | RO          | 0x000              | dfi_data_byte_disable<br>Reports the value of the output signal dfi_data_byte_disable. |
| 15:6       | RO          | 0x0                | reserved                                                                               |
| 5:4        | RO          | 0x0                | dfi_freq_ratio<br>Reports the value of the output signal dfi_freq_ratio.               |
| 3:2        | RO          | 0x0                | reserved                                                                               |
| 1          | RO          | 0x0                | dfi_init_start<br>Reports the value of the output signal dfi_init_start.               |
| 0          | RO          | 0x0                | dfi_init_complete<br>Reports the value of the input signal dfi_init_complete.          |

**DDR\_PCTL\_DFISTCFG0**

Address: Operational Base + offset (0x02c4)

DFI Status Configuration 0 Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                             |
| 2          | RW          | 0x0                | dfi_data_byte_disable_en<br>Enables the driving of the dfi_data_byte_disable signal. The value driven on dfi_data_byte_disable is dependent on the setting of PPCFG register.<br>1'b0 - Drive dfi_data_byte_disable to default value of all zeroes.<br>1'b1 - Drive dfi_data_byte_disable according to value as defined by PPCFG register setting.<br>Note: should be set to 1'b1 only after PPCFG is correctly set. |
| 1          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                             |
| 0          | RW          | 0x0                | dfi_init_start<br>Sets the value of the dfi_init_start signal.<br>1'b0 - dfi_init_start is driven low<br>1'b1 - dfi_init_start is driven high                                                                                                                                                                                                                                                                        |

**DDR\_PCTL\_DFISTCFG1**

Address: Operational Base + offset (0x02c8)

DFI Status Configuration 1 Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x0                | reserved                                                                                                                                                                                                                               |
| 0          | RW          | 0x0                | dfi_dram_clk_disable_en<br>Enables support of the dfi_dram_clk_disable signal with Self-Refresh (SR).<br>1'b0 - Disable dfi_dram_clk_disable support in relation to SR<br>1'b1 - Enable dfi_dram_clk_disable support in relation to SR |

**DDR\_PCTL\_DFITDRAMCLKEN**

Address: Operational Base + offset (0x02d0)

DFI tdram\_clk\_enable Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                 |
| 3:0        | RW          | 0x2                | tdram_clk_enable<br>Specifies the number of DFI clock cycles from the de-assertion of the dfi_dram_clk_disable signal on the DFI until the first valid rising edge 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. |

**DDR\_PCTL\_DFITDRAMCLKDIS**

Address: Operational Base + offset (0x02d4)

DFI tdram\_clk\_disable Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                       |
| 3:0        | RW          | 0x2                | tdram_clk_disable<br>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. |

**DDR\_PCTL\_DFISTCFG2**

Address: Operational Base + offset (0x02d8)

DFI Status Configuration 2 Register

| <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          | RW          | 0x0                | parity_en<br>Enables the DFI parity generation feature (driven on output signal dfi_parity_in)<br>1'b0 - Disable DFI parity generation<br>1'b1 - Enable DFI parity generation |
| 0          | RW          | 0x0                | parity_intr_en<br>Enable interrupt generation for DFI parity error (from input signal dfi_parity_error).<br>1'b0 - Disable interrupt<br>1'b1 - Enable interrupt               |

**DDR\_PCTL\_DFISTPARCLR**

Address: Operational Base + offset (0x02dc)

DFI Status Parity Clear Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                      |
| 1          | R/W SC      | 0x0                | parity_log_clr<br>Set this bit to 1'b1 to clear the DFI Status Parity Log register (DFISTPARLOG).<br>1'b0 = Do not clear DFI status Parity Log register<br>1'b1 = Clear DFI status Parity Log register                                                                        |
| 0          | R/W SC      | 0x0                | parity_intr_clr<br>Set this bit to 1'b1 to clear the interrupt generated by a DFI parity error (as enabled by DFISTCFG2.parity_intr_en). It also clears the INTRSTAT.parity_intr register field. It is automatically cleared by hardware when the interrupt has been cleared. |

**DDR\_PCTL\_DFISTPARLOG**

Address: Operational Base + offset (0x02e0)

DFI Status Parity Log Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | parity_err_cnt<br>Increments any time the DFI parity logic detects a parity error(s) (on dfi_parity_error). |

**DDR\_PCTL\_DFLPCFG0**

Address: Operational Base + offset (0x02f0)

DFI Low Power Configuration 0 Register

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28      | RW          | 0x0                | <p>dfi_lp_wakeup_dpd</p> <p>Value to drive on dfi_lp_wakeup signal when Deep Power Down mode is entered. Determines the DFI's tlp_wakeup time:</p> <ul style="list-style-type: none"> <li>4'b0000 - 16 cycles</li> <li>4'b0001 - 32 cycles</li> <li>4'b0010 - 64 cycles</li> <li>4'b0011 - 128 cycles</li> <li>4'b0100 - 256 cycles</li> <li>4'b0101 - 512 cycles</li> <li>4'b0110 - 1024 cycles</li> <li>4'b0111 - 2048 cycles</li> <li>4'b1000 - 4096 cycles</li> <li>4'b1001 - 8192 cycles</li> <li>4'b1010 - 16384 cycles</li> <li>4'b1011 - 32768 cycles</li> <li>4'b1100 - 65536 cycles</li> <li>4'b1101 - 131072 cycles</li> <li>4'b1110 - 262144 cycles</li> <li>4'b1111 - Unlimited</li> </ul> |
| 27:25      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 24         | RW          | 0x0                | <p>dfi_lp_en_dpd</p> <p>Enables DFI Low Power interface handshaking during Deep Power Down Entry/Exit.</p> <ul style="list-style-type: none"> <li>1'b0 - Disabled</li> <li>1'b1 - Enabled</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 23:20      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 19:16      | RW          | 0x7                | <p>dfi_tlp_resp</p> <p>Setting for tlp_resp time. Same value is used for both Power Down and Self-refresh and Deep Power Down modes. DFI 2.1 specification, recommends using value of 7 always.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:12      | RW          | 0x0                | <p>dfi_lp_wakeup_sr<br/> Value to drive on dfi_lp_wakeup signal when Self-Refresh mode is entered. Determines the DFI's tlp_wakeup time:</p> <p>4'b0000 - 16 cycles<br/> 4'b0001 - 32 cycles<br/> 4'b0010 - 64 cycles<br/> 4'b0011 - 128 cycles<br/> 4'b0100 - 256 cycles<br/> 4'b0101 - 512 cycles<br/> 4'b0110 - 1024 cycles<br/> 4'b0111 - 2048 cycles<br/> 4'b1000 - 4096 cycles<br/> 4'b1001 - 8192 cycles<br/> 4'b1010 - 16384 cycles<br/> 4'b1011 - 32768 cycles<br/> 4'b1100 - 65536 cycles<br/> 4'b1101 - 131072 cycles<br/> 4'b1110 - 262144 cycles<br/> 4'b1111 - Unlimited</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.</p> <p>1'b0 - Disabled<br/> 1'b1 - Enabled</p>                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 7:4        | RW          | 0x0                | <p>dfi_lp_wakeup_pd<br/> Value to drive on dfi_lp_wakeup signal when Power Down mode is entered. Determines the DFI's tlp_wakeup time:</p> <p>4'b0000 - 16 cycles<br/> 4'b0001 - 32 cycles<br/> 4'b0010 - 64 cycles<br/> 4'b0011 - 128 cycles<br/> 4'b0100 - 256 cycles<br/> 4'b0101 - 512 cycles<br/> 4'b0110 - 1024 cycles<br/> 4'b0111 - 2048 cycles<br/> 4'b1000 - 4096 cycles<br/> 4'b1001 - 8192 cycles<br/> 4'b1010 - 16384 cycles<br/> 4'b1011 - 32768 cycles<br/> 4'b1100 - 65536 cycles<br/> 4'b1101 - 131072 cycles<br/> 4'b1110 - 262144 cycles<br/> 4'b1111 - Unlimited</p>   |
| 3:1        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                             |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------|
| 0          | RW          | 0x0                | dfi_lp_en_pd<br>Enables DFI Low Power interface handshaking during Power Down Entry/Exit.<br>1'b0 - Disabled<br>1'b1 - Enabled |

**DDR\_PCTL\_DFITRWRLVLRESP0**

Address: Operational Base + offset (0x0300)

DFI Training dfi\_wrlvl\_resp Status 0 Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | dfi_wrlvl_resp0<br>Reports the status of the dif_wrlvl_resp[31:0] signal. |

**DDR\_PCTL\_DFITRWRLVLRESP1**

Address: Operational Base + offset (0x0304)

DFI Training dfi\_wrlvl\_resp Status 1 Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | dfi_wrlvl_resp1<br>Reports the status of the dif_wrlvl_resp[63:32] signal. |

**DDR\_PCTL\_DFITRWRLVLRESP2**

Address: Operational Base + offset (0x0308)

DFI Training dfi\_wrlvl\_resp Status 2 Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                                                   |
| 7:0        | RO          | 0x00               | dfi_wrlvl_resp2<br>Reports the status of the dif_wrlvl_resp[71:64] signal. |

**DDR\_PCTL\_DFITRRDLVLRESP0**

Address: Operational Base + offset (0x030c)

DFI Training dfi\_rdlvl\_resp Status 0 Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | dfi_rdlvl_resp0<br>Reports the status of the dif_rdlvl_resp[31:0] signal. |

**DDR\_PCTL\_DFITRRDLVLRESP1**

Address: Operational Base + offset (0x0310)

DFI Training dfi\_rdlvl\_resp Status 1 Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | dfi_rdlvl_resp1<br>Reports the status of the dif_rdlvl_resp[63:32] signal. |

**DDR\_PCTL\_DFITRRDLVLRESP2**

Address: Operational Base + offset (0x0314)

## DFI Training dfi\_rdlvl\_resp Status 2 Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                                                   |
| 7:0        | RO          | 0x00               | dfi_rdlvl_resp2<br>Reports the status of the dif_rdlvl_resp[71:64] signal. |

**DDR\_PCTL\_DFITRWRLVLDELAY0**

Address: Operational Base + offset (0x0318)

DFI Training dfi\_wrlvl\_delay Configuration 0 Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | dfi_wrlvl_delay0<br>Sets the value to be driven on the signal dfi_wrlvl_delay_x[31:0]. |

**DDR\_PCTL\_DFITRWRLVLDELAY1**

Address: Operational Base + offset (0x031c)

DFI Training dfi\_wrlvl\_delay Configuration 1 Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | dfi_wrlvl_delay1<br>Sets the value to be driven on the signal dfi_wrlvl_delay_x[63:32]. |

**DDR\_PCTL\_DFITRWRLVLDELAY2**

Address: Operational Base + offset (0x0320)

DFI Training dfi\_wrlvl\_delay Configuration 2 Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                                                                |
| 7:0        | RW          | 0x00               | dfi_wrlvl_delay2<br>Sets the value to be driven on the signal dfi_wrlvl_delay_x[71:64]. |

**DDR\_PCTL\_DFITRRDLVLDELAY0**

Address: Operational Base + offset (0x0324)

DFI Training dfi\_rdlvl\_delay Configuration 0 Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | dfi_rdlvl_delay0<br>Sets the value to be driven on the signal dfi_rdlvl_delay_x[31:0]. |

**DDR\_PCTL\_DFITRRDLVLDELAY1**

Address: Operational Base + offset (0x0328)

DFI Training dfi\_rdlvl\_delay Configuration 1 Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | dfi_rdlvl_delay1<br>Sets the value to be driven on the signal dfi_rdlvl_delay_x[63:32]. |

**DDR\_PCTL\_DFITRRDLVLDELAY2**

Address: Operational Base + offset (0x032c)

DFI Training dfi\_rdlvl\_delay Configuration 2 Register

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                                                                |
| 7:0        | RW          | 0x00               | dfi_rdlvl_delay2<br>Sets the value to be driven on the signal dfi_rdlvl_delay_x[71:64]. |

**DDR\_PCTL\_DFITRRDLVLGATEDELAY0**

Address: Operational Base + offset (0x0330)

DFI Training dfi\_rdlvl\_gate\_delay Configuration 0

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                               |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | dfi_rdlvl_gate_delay0<br>Sets the value to be driven on the signal dfi_rdlvl_gate_delay_x[31:0]. |

**DDR\_PCTL\_DFITRRDLVLGATEDELAY1**

Address: Operational Base + offset (0x0334)

DFI Training dfi\_rdlvl\_gate\_delay Configuration 1

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | dfi_rdlvl_gate_delay1<br>Sets the value to be driven on the signal dfi_rdlvl_gate_delay_x[63:32]. |

**DDR\_PCTL\_DFITRRDLVLGATEDELAY2**

Address: Operational Base + offset (0x0338)

DFI Training dfi\_rdlvl\_gate\_delay Configuration 2

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                                                                          |
| 7:0        | RW          | 0x00               | dfi_rdlvl_gate_delay2<br>Sets the value to be driven on the signal dfi_rdlvl_gate_delay_x[71:64]. |

**DDR\_PCTL\_DFITRCMD**

Address: Operational Base + offset (0x033c)

DFI Training Command Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | R/W SC      | 0x0                | dfitrcmd_start<br>DFI Training Command Start. When this bit is set to 1, the command operation defined in the dfitrcmd_opcode field is started. This bit is automatically cleared by the controller after the command is finished. The application can poll this bit to determine when controller is ready to accept another command. This bit cannot be cleared to 1b0 by software. |
| 30:13      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                             |
| 12:4       | RW          | 0x000              | dfitrcmd_en<br>DFI Training Command Enable. Selects which bits of chosen DFI Training command to drive to 1'b1.                                                                                                                                                                                                                                                                      |
| 3:2        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                             |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                             |
|-----|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0 | RW   | 0x0         | dfitrcmd_opcode<br>DFI Training Command Opcode. Select which DFI Training command to generate for one n_clk cycle:<br>2'b00 - dfi_wrlvl_load<br>2'b01 - dfi_wrlvl_strobe<br>2'b10 - dfi_rdlvl_load<br>2'b11 - Reserved. |

**DDR\_PCTL\_IPVR**

Address: Operational Base + offset (0x03f8)

IP Version Register

| Bit  | Attr | Reset Value | Description                                               |
|------|------|-------------|-----------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | ip_version<br>ASCII value for each number in the version. |

**DDR\_PCTL\_IPTR**

Address: Operational Base + offset (0x03fc)

IP Type Register

| Bit  | Attr | Reset Value | Description                                                                                                                                                                |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0x44574300  | ip_type<br>Contains the IP's identification code, which is an ASCII value to identify the component and it is currently set to the string "DWC". This value never changes. |

**6.5 Timing Diagram****6.5.1 DDR3 Read/Write Access Timing**

Fig. 6-4 DDR3 burst write operation: AL=0, CWL=4, BC4



Fig. 6-5 DDR3 burst read operation: AL=0, CL=5, BC4

Table 6-1 meaning of the parameter

| Parameter | Description | DDR3-800 | unit |
|-----------|-------------|----------|------|
|-----------|-------------|----------|------|

|                    |                                                  | <b>min</b> | <b>max</b> |     |
|--------------------|--------------------------------------------------|------------|------------|-----|
| t <sub>CH</sub>    | CK HIGH pulse width                              | 0.43       | -          | tCK |
| t <sub>CL</sub>    | CK LOW pulse width                               | 0.43       | -          | tCK |
| t <sub>DS</sub>    | DQ and DM input setup time (differential strobe) | 75         | -          | ps  |
| t <sub>DH</sub>    | DQ and DM input hold time (differential strobe)  | 150        | -          | ps  |
| t <sub>DSS</sub>   | DQS falling edge to CK setup time                | 0.2        | -          | tCK |
| t <sub>DSH</sub>   | DQS falling edge hold time from CK               | 0.2        | -          | tCK |
| t <sub>IS</sub>    | Address and control input setup time             | 200        | -          | ps  |
| t <sub>IH</sub>    | Address and control input hold time              | 275        | -          | ps  |
| t <sub>WPRE</sub>  | Write preamble                                   | 0.9        | -          | tCK |
| t <sub>WPST</sub>  | Write postamble                                  | 0.3        | -          | tCK |
| t <sub>RPRE</sub>  | Read preamble                                    | 0.9        | 1.1        | tCK |
| t <sub>RPST</sub>  | Read postamble                                   | 0.3        | 0.5        | tCK |
| t <sub>DQSCK</sub> | DQS output access time from CK/CK_n              | -400       | +400       | ps  |
| t <sub>DQSQ</sub>  | DQS-DQ skew for DQS and associated DQ signals    | -          | 200        | ps  |
| t <sub>QH</sub>    | DQ/DQS output hold time from DQS                 | 0.38       | -          | tCK |

## 6.6 Interface Description

DDR IOs are listed as following Table.

Table 6-2 DDR IO description

| <b>Pin Name</b> | <b>Description</b>                                                             |
|-----------------|--------------------------------------------------------------------------------|
| CK              | Active-high clock signal to the memory device.                                 |
| CK_B            | Active-low clock signal to the memory device.                                  |
| CKE             | Active-high clock enable signal to the memory device for two chip select.      |
| CS_Bi (i=0,1)   | Active-low chip select signal to the memory device. There are two chip select. |
| RAS_B           | Active-low row address strobe to the memory device.                            |
| CAS_B           | Active-low column address strobe to the memory device.                         |
| WE_B            | Active-low write enable strobe to the memory device.                           |
| BA[2:0]         | Bank address signal to the memory device.                                      |
| A[15:0]         | Address signal to the memory device.                                           |
| DQ[15:0]        | Bidirectional data line to the memory device.                                  |
| DQS[1:0]        | Active-high bidirectional data strobes to the memory device.                   |
| DQS_B[1:0]      | Active-low bidirectional data strobes to the memory device.                    |
| DM[1:0]         | Active-low data mask signal to the memory device.                              |
| ODTi (i=0,1)    | On-Die Termination output signal for two chip select.                          |
| RESET           | DDR3 reset signal.                                                             |

## 6.7 Application Notes

### 6.7.1 State transition of PCTL

To operate PCTL, the programmer must be familiar with the available operational states and how to transition to each state from the current state.

Every software programmable register is accessible only during certain operational states. For information about what registers are accessible in each state, refer to "Software Registers," which provides this information in each register description. The general rule is that the PCTL must be in the Init\_mem or ConFig states to successfully write most of the registers.

The following tables provide the programming sequences for moving to the various states of the state machine.

**Moving to the Init\_mem State**

| <b>Step</b> | <b>Application</b>                                                 | <b>PCTL</b>                                                                                                                                                 |
|-------------|--------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1           | Read STAT register                                                 | Returns the current PCTL state.                                                                                                                             |
| 2           | If STAT.ctl_stat = Init_mem, go to END.                            |                                                                                                                                                             |
| 3           | If STAT.ctl_stat = Config, go to Step9.                            |                                                                                                                                                             |
| 4           | If STAT.ctl_stat = Access, go to Step8.                            |                                                                                                                                                             |
| 5           | If STAT.ctl_stat = Low_power,<br>go to Step7.                      |                                                                                                                                                             |
| 6           | Goto Step1.                                                        | PCTL is in a Transitional state and not in any of the previous operational states.                                                                          |
| 7           | Write WAKEUP to SCTL.state_cmd and poll<br>STAT.ctl_stat = Access. | Issues SRX, moves to the Access state, updates<br>STAT.ctl_stat = Access when complete.                                                                     |
| 8           | Write CFG to SCTL.state_cmd and poll<br>STAT.ctl_stat = ConFig     | PCTL stalls the NIF; completes any pending transaction; issues PREA if required; moves into the ConFig state; updates STAT.ctl_stat = ConFig when complete. |
| 9           | Write INIT to SCTL.state_cmd and poll<br>STAT.ctl_stat = Init_mem  | Moves into the Init_mem state and updates<br>STAT.ctl_stat = Init_mem.                                                                                      |
| END         |                                                                    | PCTL is in Init_mem state.                                                                                                                                  |

**Moving to ConFig State**

| <b>Step</b> | <b>Application</b>                                                | <b>PCTL</b>                                                                                                                                                     |
|-------------|-------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1           | Read STAT register.                                               | Returns the current PCTL state.                                                                                                                                 |
| 2           | If STAT.ctl_stat = Config, goto END.                              |                                                                                                                                                                 |
| 3           | If STAT.ctl_stat = Low_power, go to Step6.                        |                                                                                                                                                                 |
| 4           | If STAT.ctl_stat = Init_mem or Access, go to Step7.               |                                                                                                                                                                 |
| 5           | Go to Step1.                                                      | PCTL is in a transitional state and is not in any of the previous operational states.                                                                           |
| 6           | Write WAKEUP to CTL.state_cmd and poll<br>STAT.ctl_stat = Access. | Issues SRX, moves to the Access state, and updates STAT.ctl_stat = Access when complete.                                                                        |
| 7           | Write CFG to SCTL.state_cmd and poll<br>STAT.ctl_stat = ConFig    | PCTL stalls the NIF; completes any pending transaction; issues PREA if required; moves into the ConFig state; and updates STAT.ctl_stat = ConFig when complete. |
| END         |                                                                   | PCTL is in ConFig state.                                                                                                                                        |

**Moving to Access State**

| <b>Step</b> | <b>Application</b>                       | <b>PCTL</b>                     |
|-------------|------------------------------------------|---------------------------------|
| 1           | Read STAT register                       | Returns the current PCTL state. |
| 2           | If STAT.ctl_stat = Access, go to END.    |                                 |
| 3           | If STAT.ctl_stat = Config, go to Step9   |                                 |
| 4           | If STAT.ctl_stat = Init_mem, go to Step8 |                                 |

| <b>Step</b> | <b>Application</b>                                                      | <b>PCTL</b>                                                                           |
|-------------|-------------------------------------------------------------------------|---------------------------------------------------------------------------------------|
| 5           | If STATctl_stat = Low_power, go to Step7.                               |                                                                                       |
| 6           | Goto Step1.                                                             | PCTL is in a transitional state and is not in any of the previous operational states. |
| 7           | Write WAKEUP to SCTL.state_cmd and poll STATctl_stat = Access. Goto END | Issues SRX, moves to the Access state, updates STATctl_stat = Access when complete.   |
| 8           | Write CFG to SCTL.state_cmd and poll STATctl_stat = ConFig              | Moves into the ConFig state, updates STATctl_stat = ConFig when complete.             |
| 9           | Write GO to SCTL.state_cmd and poll STATctl_stat = Access.              | Moves into the Access state, updates STATctl_stat = Access when complete.             |
| END         |                                                                         | PCTL is in Access state.                                                              |

**Moving to Low Power State**

| <b>Step</b> | <b>Application</b>                                               | <b>PCTL</b>                                                                                                                                 |
|-------------|------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| 1           | Read STAT register.                                              | Returns current PCTL state.                                                                                                                 |
| 2           | If STATctl_stat = Low_power, go to END.                          |                                                                                                                                             |
| 3           | If STATctl_stat = Access, go to Step9                            |                                                                                                                                             |
| 4           | If STATctl_stat = Config, go to Step8                            |                                                                                                                                             |
| 5           | If STATctl_stat = Init_mem, go to Step7.                         |                                                                                                                                             |
| 6           | Goto Step1.                                                      | PCTL is in transitional state and is not in any of the previous operational states.                                                         |
| 7           | Write CFG to SCTL.state_cmd and poll STATctl_stat = ConFig       | Moves into the ConFig state, updates STATctl_stat = ConFig when complete.                                                                   |
| 8           | Write GO to SCTL.state_cmd and poll STATctl_stat = Access.       | Moves into the Access state, updates STATctl_stat = Access when complete.                                                                   |
| 9           | Write SLEEP to SCTL.state_cmd and poll STATctl_stat = Low_power. | Issues PDX if necessary; completes any pending transactions; issues PREA command; finally, issues SRE and updates STATctl_stat = Low_power. |
| END         |                                                                  | PCTL is in Low Power state                                                                                                                  |

**6.7.2 Initialization****PHY Initialization**

DDR PHY power-up reset sequence:

1. PHY Register Reset: reset the PHY register block through presetn;
2. Configure registers: AL, CL etc. (register address 0x38)
3. System reset: reset the PHY through system\_rstn;
4. Soft reset (optional): after system reset, execute the soft reset by changing PHY\_REG0 values. Soft reset function is on when PHY\_REG0[3:2] = 2'b11.
5. Start PHY initialization: after pclk, dfi\_clk1x and dfi\_clk2x clock signals are stable, initialize the PHY.
6. Start PHY Calibration: after ddr sdram initialization done, you can set PHY calibration start.
7. Close PHY Calibration: after step 5us, you can set close PHY calibration.
8. Start Write and Read.

**DDR3 Initialization Sequence**

The initialization steps for DDR3 SDRAMs are as follows:

1. Optionally maintain RESET# low for a minimum of either 200 us (power-up initialization) or

100ns (power-on initialization). The DDR PHY drives RESET# low from the beginning of reset assertion and therefore this step may be skipped when DRAM initialization is triggered if enough time may already have expired to satisfy the RESET# low time.

2. After RESET# is de-asserted, wait a minimum of 500 us with CKE low.
3. Apply NOP and drive CKE high.
4. Wait a minimum of tXPR.
5. Issue a load Mode Register 2 (MR2) command.
6. Issue a load Mode Register 3 (MR3) command.
7. Issue a load Mode Register (MR1) command (to set parameters and enable DLL).
8. Issue a load Mode Register (MR0) command to set parameters and reset DLL.
9. Issue ZQ calibration command.
10. Wait 512 SDRAM clock cycles for the DLL to lock (tDLLK) and ZQ calibration (tZQinit) to finish. This wait time is relative to Step 8, i.e. relative to when the DLL reset command was issued onto the SDRAM command bus.

### 6.7.3 Low Power Operation

Low\_power state can be entered/exited via following ways:

- Software control of PCTL State machine (highest priority)
- Hardware Low Power Interface (middle priority)
- Auto Self-Refresh feature (lowest priority)

Note the priority of requests from Access to Low\_power is highlighted above. The STAT.ip\_trig register field reports which of the 3 requests caused the entry to Low\_power state.

#### Software control of PCTL State

The application can request via software to enter the memories into Self-Refresh state by issuing the SLEEP command by programming SCTL.PCTL responds to the software request by moving into the Low\_power operational state and issuing the SRE command to the memories. Note that the Low\_power state can only be reached from the Access state.

In a similar fashion, the application requests to exit the memories from Self-Refresh by issuing a WAKEUP command by programming SCTL. PCTL responds to the WAKEUP command issuing SRX and restoring normal NIF address channel operation.

#### Hardware Low Power Interface

The hardware low power interface can also be used to enter/exit Self-Refresh. The functionality is enabled by setting SCFG.hw\_low\_power\_en=1. Once that bit is set, the input c\_sysreq has the ability to trigger entry into the Low Power configuration state just like the software methodology (SCTL.state\_cmd = SLEEP). A hardware Low Power entry trigger will be ignored/denied if the input c\_active\_in=1 or n\_valid=1. It may be accepted if c\_active\_in=0 and n\_valid=0, depending on the current state of the PCTL. When SCFG.hw\_low\_power\_en=1, the outputs c\_sysack and c\_active provide feedback as required by the AXI low power interface specification (this interface's operation is defined by the AXI specification). c\_sysack acknowledges the request to go into the Low\_power state, and c\_active indicates when the PCTL is actually in the Low\_power state.

The c\_active output could also be used by an external Low Power controller to decide when to request a transition to low power. When MCFG1.hw\_idle > 0, c\_active = 1'b0 indicates that the NIF has been idle for at least MCFG1.hw\_idle \* 32 \* n\_clk cycles while in the Access state. When in low power the c\_active output can be used by an external Low Power controller to trigger a low power exit. c\_active will be driven high when either c\_active\_in or n\_valid are high. The path from c\_active\_in and n\_valid to c\_active is asynchronous so even if the clocks have been removed c\_active will assert. The Low Power controller should re-enable the clocks when c\_active is driven high while in the Low\_power state.

#### Auto Power Down/Self-Refresh

The Power Down and/or Self-Refresh sequence is automatically started by PCTL when the NIF address channel is idle for a number of cycles, depending on the programmed value in MCFG.pd\_idle and MCFG1.sr\_idle.

Following table outlines the effect of these settings in conjunction with NIF being idle.

| <b>pd_idle</b> | <b>sr_idle</b> | <b>Memory modes</b> | <b>Memory Type</b> |
|----------------|----------------|---------------------|--------------------|
| 0              | 0              | none                | All                |
| >0             | 0              | Power Down          | All                |

| <b>pd_idle</b> | <b>sr_idle</b> | <b>Memory modes</b>                     | <b>Memory Type</b> |
|----------------|----------------|-----------------------------------------|--------------------|
| 0              | >0             | Self-Refresh                            | All                |
| >0             | >0             | Power Down -> Self Refresh <sup>3</sup> | All                |

Note:

1. Power Down is entered if NIF is idle for pd\_idle. Following on from that, if NIF continues to be idle for a further sr\_idle\*32 cycles, Power Down is exited and Self-Refresh is entered.
2. Following on from that, if NIF continues to be idle for a further sr\_idle\*32 cycles, Power Down is exited and Self-Refresh is entered.

### Removing PCTL's n\_clk

In DDR3, the relationship between SRE/SRX and stopping/starting the memory clock (CK) are formalized and are accounted for automatically by PCTL. With DDR3, CK should only be stopped after PCTL has reached the Low\_power state. The current operational state can be verified by reading STAT.ctl\_stat. The CK must be started and stable before the Software or Hardware Low Power Interface attempts to take the memory out of Self-Refresh.

PCTL's n\_clk can be safely removed when PCTL is in Low Power state. The sequences outlined in following two tables should be followed for safe operation:

| <b>Step</b> | <b>Application</b>                                                                                                                               | <b>PCTL</b>                                                                   |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------|
| 1           | Write SLEEP to SCTL.state_cmd and poll STAT.ctl_stat = LOW_POWER.                                                                                | Tells PCTL to move memories into Self-Refresh and waits until this completes. |
| 2           | Write TREFI=0. Also, write DFITCRLUPDI=0 and DFIREFMSKI=0, if they are not already 0.                                                            | Stops any MC-driven DFI updates occurring internally with PCTL                |
| 3           | Wait a minimum interval which is equivalent to the PCTL's Refresh Interval (previous value of TREFI * TOGCNT100N * internal timers clock period; | Ensures any already scheduled PHY/PVT updates have completed successfully.    |
| 4           | Stop toggling n_clk to PCTL.                                                                                                                     | n_clk logic inside PCTL is stopped.                                           |
| end         |                                                                                                                                                  |                                                                               |

| <b>Step</b> | <b>Application</b>                                                                                                                                       | <b>PCTL</b>                                                          |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|
| 1           | Drive c_active_in low                                                                                                                                    | Confirms that system external to PCTL can accept a Low-power request |
| 2           | Drive c_sysreq low                                                                                                                                       | System Low-power request                                             |
| 3           | Wait for PCTL to drive c_sysack low                                                                                                                      | PCTL Low-power request acknowledgement                               |
| 4           | Check value of c_active when Step 3 occurs.<br>- if c_active=1, request denied. Cannot remove n_clk.<br>Go to END.<br>- if c_active=0, request accepted. | PCTL low-power request status response                               |
| 5           | Stop toggling n_clk to PCTL                                                                                                                              | n_clk logic inside PCTL is stopped                                   |
| end         |                                                                                                                                                          |                                                                      |

### 6.7.4 TX DLLs

All high speed IO signals' phase can be adjusted by TX DLLs. Table 1-3 illustrates these DLLs.

Table 6-3 DDR PHY TX DLLs Delay Step

| <b>Offset</b> | <b>Bit</b> | <b>Control Signal Phase</b> | <b>Default</b> | <b>Description</b> |
|---------------|------------|-----------------------------|----------------|--------------------|
| 0x60          | 2~0        | CMD                         | 0x0            | CMD DLL delay step |
| 0x68          | 2~0        | CK                          | 0x0            | CK DLL delay step  |
| 0xd4          | 2~0        | DM0, DQ7~DQ0                | 0x4            | DM and DQ DLL      |
| 0x114         | 2~0        | DM1, DQ15~DQ8               | 0x4            | Signal delay step  |
| 0xd8          | 2~0        | DQS0, DQSBO                 | 0x0            | TX DQS DLL Signal  |

| Offset | Bit | Control Signal Phase | Default | Description |
|--------|-----|----------------------|---------|-------------|
| 0x118  | 2~0 | DQS1, DQSB1          | 0x0     | delay step  |

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.

## 6.7.5 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 6-4 DDR PHY RX DQS Delay Step

| Offset | Bit | Control Signal Phase | Default | Description                  |
|--------|-----|----------------------|---------|------------------------------|
| 0xe0   | 5~3 | Left DQS squelch     | 0x0     | Left DQS squelch delay step  |
|        | 1~0 | DQS0, DQSB0          | 0x0     | Left Rx DQS delay step       |
| 0x120  | 5~3 | Right DQS squelch    | 0x0     | Right DQS squelch delay step |
|        | 1~0 | DQS1, DQSB1          | 0x0     | Right Rx DQS delay step      |

## 6.7.6 High Speed IO Drive Strength

The tuning range of driver resistance is 28ohm to 138ohm. By default, 0x5 is 46ohm for DDR3 CMD driver. When the control bit is set to be larger, the drive strength becomes stronger.

Table 6-5 DM/DQ/DQS/CMD Driver output resistance

| Offset | Bit | Default | Description                         |
|--------|-----|---------|-------------------------------------|
| 0x54   | 7~4 | 0x7     | adjustable CMD pull-up resistance   |
|        | 3~0 | 0x7     | adjustable CMD pull-down resistance |
| 0x70   | 7~4 | 0x7     | adjustable CK pull-up resistance    |
|        | 3~0 | 0x7     | adjustable CK pull-down resistance  |

Table 6-6 DM, DQ Signal Drive Strength Register

| Offset | Bit | Default | Description                                             |
|--------|-----|---------|---------------------------------------------------------|
| 0x80   | 7~4 | 0x7     | Low 8bit adjustable DQ/DQS pull-up resistance           |
|        | 3~0 | 0x7     | Low 8bit adjustable DQ/DQS pull-down resistance         |
| 0x84   | 7~4 | 0x7     | High 8bit adjustable DQ/DQS pull-up resistance          |
|        | 3~0 | 0x7     | High 8bit adjustable DQ/DQS pull-down resistance        |
| 0x88   | 7~4 | 0x7     | Low 8bit adjustable DQ/DQS RX ODT pull-up resistance    |
|        | 3~0 | 0x7     | Low 8bit adjustable DQ/DQS RX ODT pull-down resistance  |
| 0x8c   | 7~4 | 0x7     | High 8bit adjustable DQ/DQS RX ODT pull-up resistance   |
|        | 3~0 | 0x7     | High 8bit adjustable DQ/DQS RX ODT pull-down resistance |

The value is larger, the drive strength is stronger.

Table 6-7 DM/DQ/DQS/CMD Driver output resistance with control bit

| Control bit          | 4'b0000 | 4'b0001 | 4'b0010 | 4'b0011 | 4'b0100 | 4'b0101 | 4'b0110 | 4'b0111 |
|----------------------|---------|---------|---------|---------|---------|---------|---------|---------|
| Pull-up resistance   | +∞      | 309ohm  | 155ohm  | 103ohm  | 77ohm   | 63ohm   | 52ohm   | 45ohm   |
| Pull-down resistance | +∞      | 309ohm  | 155ohm  | 103ohm  | 77ohm   | 63ohm   | 52ohm   | 45ohm   |
| Control bit          | 4'b1000 | 4'b1001 | 4'b1010 | 4'b1011 | 4'b1100 | 4'b1101 | 4'b1110 | 4'b1111 |
| Pull-up resistance   | 77ohm   | 62ohm   | 52ohm   | 44ohm   | 39ohm   | 34ohm   | 31ohm   | 28ohm   |
| Pull-down resistance | 77ohm   | 62ohm   | 52ohm   | 44ohm   | 39ohm   | 34ohm   | 31ohm   | 28ohm   |

Table 6-8 DM/DQ/DQS RX ODT resistance with control bit

| Control bit          | 4'b0000 | 4'b0001 | 4'b0010 | 4'b0011 | 4'b0100 | 4'b0101 | 4'b0110 | 4'b0111 |
|----------------------|---------|---------|---------|---------|---------|---------|---------|---------|
| Pull-up resistance   | +∞      | 861ohm  | 431ohm  | 287ohm  | 216ohm  | 172ohm  | 145ohm  | 124ohm  |
| Pull-down resistance | +∞      | 861ohm  | 431ohm  | 287ohm  | 216ohm  | 172ohm  | 145ohm  | 124ohm  |
| Control bit          | 4'b1000 | 4'b1001 | 4'b1010 | 4'b1011 | 4'b1100 | 4'b1101 | 4'b1110 | 4'b1111 |
| Pull-up resistance   | 215ohm  | 172ohm  | 144ohm  | 123ohm  | 108ohm  | 96ohm   | 86ohm   | 78ohm   |
| Pull-down resistance | 215ohm  | 172ohm  | 144ohm  | 123ohm  | 108ohm  | 96ohm   | 86ohm   | 78ohm   |

### 6.7.7 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 enters low power mode when setting DLLs into Bypass mode. Table 10-9 illustrates related register settings.

Table 6-9 Low Power DLL Setting

| Offset | Bit | Default | Low power Setting | Description                                 |
|--------|-----|---------|-------------------|---------------------------------------------|
| 0x2b0  | 4   | 0x0     | 0x1               | CMD DLL in bypass mode                      |
|        | 3   | 0x0     | 0x1               | DQS1/DQSB1 DM1, DQ15~DQ8 DLL in bypass mode |
|        | 2   | 0x0     | 0x1               | DQS0/DQSB0 DM0 DQ7~DQ0 DLL in bypass mode   |
| 0x60   | 4   | 0x0     | 0x0               | CMD DLL not inversion mode                  |
|        | 3   | 0x1     | 0x1               | CMD DLL enable, active HIGH                 |
|        | 2~0 | 0x0     | 0x0               | N/A                                         |
| 0xd4   | 4   | 0x0     | 0x1               | DM1, DQ15~DQ8 inversion mode                |
|        | 3   | 0x1     | 0x1               | DM1, DQ15~DQ8 DLL enable                    |
|        | 2~0 | 0x4     | 0x0               | N/A                                         |
| 0x114  | 4   | 0x0     | 0x1               | DM0, DQ7~DQ0 inversion mode                 |
|        | 3   | 0x1     | 0x1               | DM1, DQ7~DQ0 DLL enable                     |
|        | 2~0 | 0x4     | 0x0               | N/A                                         |
| 0xd8   | 3   | 0x0     | 0x0               | DQS0/DQSB0 not inversion mode               |
|        | 2~0 | 0x0     | 0x0               | N/A                                         |
| 0x118  | 3   | 0x0     | 0x0               | DQS1/DQSB1 not inversion mode               |
|        | 2~0 | 0x0     | 0x0               | N/A                                         |

### 6.7.8 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 6-10 per-bit de-skew tuning resolution

|                    | ff   | tt   | ss   |
|--------------------|------|------|------|
| de-skew resolution | 15ps | 20ps | 30ps |

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

### 6.7.9 DDR PHY Calibration

DDR PHY auto-adjustment function has been implemented in the PHY. The entire training processes only need to modify the register to start and complete enough.

The entire training process is as follows:

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

| Offset | Bit | Default | Description                                         |
|--------|-----|---------|-----------------------------------------------------|
| 0x8    | 7~2 | 0x0     | Others register                                     |
|        | 1   | 0x0     | set calibration bypass mode(1:bypass mode; 0:nomal) |
|        | 0   | 0x0     | set calibration start (1: start; 0: stop)           |

4. After setting register in 5us complete calibration, see the calibration register can be read at this time is complete.

5. Normal read and writes operation can begin.

The software training process is as follows:

1. PHY's register is reset, the setup is complete.
2. Controller to send the initial command and to complete initialization.
3. Set the PHY's register calibration bypass mode.
4. Send 4 consecutive burst8/4 read command.
5. Read register address 0x3c4 value idqs.
6. According to the state diagram shown below to change the cycle ophse dll value.
7. Repeat 4, 5, 6 until you have completed.

Rockchip Confidential

## Chapter 7 Nand Flash Controller (NandC)

### 7.1 Overview

Nand Flash Controller (NandC) is used to control data transmission from host to flash device or from flash device to host. NandC is connected to AHB BUS through an AHB Master and an AHB Slave. The data transmission between host and external memory can be done through AHB Master interface or AHB Slave interface.

NandC supports the following features:

- Software Interface Type
  - Support directly mode
  - Support LLP(Linked List Pointer) mode
- Flash Interface Type
  - Support Asynchronous Flash Interface with 8bits data width ("Asyn8x" for short)
  - Support 1 flash devices
- Flash Type
  - Support Managed NAND Flash(LBA) and Raw NAND Flash(NO-LBA)
  - Support SLC/MLC/TLC Flash
- Flash Interface Timing
  - Asyn8x: configurable timing, one byte per two host clocks at the fastest speed
- Randomizer Ability
  - Support two randomizer mode with different polynomial
    - Support two randomizer width, 8bit and 16bit parallel
- BCH/ECC Ability
  - 16bit/1KB BCH/ECC: support 16bitBCH/ECC, which can detect and correct up to 16 error bits in every 1K bytes data
  - 24bit/1KB BCH/ECC: support 24bitBCH/ECC, which can detect and correct up to 24 error bits in every 1K bytes data
  - 40bit/1KB BCH/ECC: support 40bitBCH/ECC, which can detect and correct up to 40 error bits in every 1K bytes data
  - 60bit/1KB BCH/ECC: support 60bitBCH/ECC, which can detect and correct up to 60 error bits in every 1K bytes data
  - 8bit/512B BCH/ECC: support 8bitBCH/ECC, which can detect and correct up to 8 error bits in every 512 bytes data
  - 12bit/512B BCH/ECC: support 12bitBCH/ECC, which can detect and correct up to 12 error bits in every 512 bytes data
  - 20bit/512B BCH/ECC: support 20bitBCH/ECC, which can detect and correct up to 20 error bits in every 512 bytes data
  - 30bit/512B BCH/ECC: support 30bitBCH/ECC, which can detect and correct up to 30 error bits in every 512 bytes data
  - 16bit/512B BCH/ECC: support 16bitBCH/ECC, which can detect and correct up to 16 error bits in every 512 bytes data
  - 24bit/512B BCH/ECC: support 24bitBCH/ECC, which can detect and correct up to 24 error bits in every 512 bytes data
  - 40bit/512B BCH/ECC: support 40bitBCH/ECC, which can detect and correct up to 40 error bits in every 512 bytes data
  - 60bit/512B BCH/ECC: support 60bitBCH/ECC, which can detect and correct up to 60 error bits in every 512 bytes data
- Transmission Ability
  - Support 16K bytes data transmission at a time at most
  - Support two transfer working modes: Bypass or DMA
  - Support two transfer codeword size for Managed NAND Flash: 1024 bytes/codeword or 512 bytes/codeword
- Internal Memory
  - 2 built-in SRAMs, and the size is 1k bytes respectively
  - Can be accessed by other masters
  - Can be operated in pingpong mode by other masters

## 7.2 Block Diagram

NandC comprises with:

- MIF: AHB Master Interface
- SIF : AHB Slave Interface
- SRIF : SRAM Interface
- TRANSC : Transfer Controller
- LLPC : LLP Controller
- BCHENC : BCH Encoder
- BCHDEC : BCH Decoder
- RANDMZ : Randomizer
- FIF\_GEN : Flash Interface Generation
- DLC : Delay Line Controller



Fig. 7-1 NandC Block Diagram

## 7.3 Function Description

### 7.3.1 AHB Interface

There is an AHB master interface in NandC, which is selectable and configurable. It is responsible for transferring data from external memory to internal memory when flash program, or inverse when flash read; and transferring LLP data from external memory to internal register file when LLP is active.

There is an AHB slave interface in NandC. It is responsible for accessing registers and internal memories. The addresses of these registers and memories are listed in Register Description section.

### 7.3.2 Flash Type/Flash Interface

Only asynchronous 8bits flash interface is supported in this design. You can use it by software (configure FMCTL) to suit for these devices. Also you can configure its timing parameters by software (configure FMWAIT\_ASYN) to have your desired rate.

### 7.3.3 Linked List Pointer Mode (LLP)

To save the software resource and improve the performance, a LLP is add, which is selectable. When LLP is selected, the flash operation instructions stored in external memory with specific format should be loaded for flash working. The detailed format and working flow are referred to LLP Application section.

### 7.3.4 BCH Encoder/BCH Decoder

The BCH Encoder is responsible for encoding data to be written into flash device. The max encoded length is 1133bytes,in which the data length is 1024bytes, system information is 4bytes, BCH code is 105bytes.

The BCH Decoder is responsible for decoding data read from flash device. The max decoded

length is 1133bytes, in which the data length is 1024bytes, spare length is 109bytes.

### 7.3.5 Randomizer

To improve device lifetime, a randomizer is added in NandC. It includes two parts: Scrambler and Descrambler, which is responsible for scrambling data to be written into flash after bch encoding, and descrambling data read from flash before bch decoding.

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

Table 7-1 NandC Address Mapping

| Base Address[12:8] | Device | Address Length | Offset Address Range |
|--------------------|--------|----------------|----------------------|
| 5'b00_00x(x=0, 1)  | FLR    | 512 BYTE       | 0x0000 ~ 0x01ff      |
| 5'b00_01x(x=0, 1)  | SPR    | 512 BYTE       | 0x0200 ~ 0x03ff      |
| 5'b00_10x(x=0, 1)  | FLR1   | 512 BYTE       | 0x0400 ~ 0x05ff      |
| 5'b01_000          | Flash0 | 256 BYTE       | 0x0800 ~ 0x08ff      |
| 5'b01_001          | Flash1 | 256 BYTE       | 0x0900 ~ 0x09ff      |
| 5'b01_010          | Flash2 | 256 BYTE       | 0x0a00 ~ 0x0aff      |
| 5'b01_011          | Flash3 | 256 BYTE       | 0x0b00 ~ 0x0bff      |
| 5'b01_100          | Flash4 | 256 BYTE       | 0x0c00 ~ 0x0cff      |
| 5'b01_101          | Flash5 | 256 BYTE       | 0x0d00 ~ 0x0dff      |
| 5'b01_110          | Flash6 | 256 BYTE       | 0x0e00 ~ 0x0eff      |
| 5'b01_111          | Flash7 | 256 BYTE       | 0x0f00 ~ 0x0fff      |
| 5'b10_0xx(x=0, 1)  | Sram0  | 1K BYTE        | 0x1000 ~ 0x13ff      |
| 5'b10_1xx(x=0, 1)  | Sram1  | 1K BYTE        | 0x1400 ~ 0x17ff      |

### 7.4.2 Registers Summary

| Name                | Offset | Size | Reset Value | Description                                           |
|---------------------|--------|------|-------------|-------------------------------------------------------|
| NANDC_FMCTL         | 0x0000 | W    | 0x000000200 | Flash interface control register                      |
| NANDC_FMWAIT_ASYN   | 0x0004 | W    | 0x3f03f7ff  | Flash timing control register for asynchronous timing |
| NANDC_FLCTL         | 0x0008 | W    | 0x00100000  | Internal transfer control register                    |
| NANDC_BCHCTL        | 0x000c | W    | 0x00000008  | BCH control register                                  |
| NANDC_MTRANS_CFG    | 0x0010 | W    | 0x000001d0  | Bus transfer configuration register                   |
| NANDC_MTRANS_SADDR0 | 0x0014 | W    | 0x000000000 | Start address register for page data transfer         |
| NANDC_MTRANS_SADDR1 | 0x0018 | W    | 0x000000000 | Start address register for spare data transfer        |
| NANDC_MTRANS_STAT   | 0x001c | W    | 0x000000000 | Bus transfer status register                          |
| NANDC_BCHST0        | 0x0020 | W    | 0x040000000 | BCH status register for codeword 0~1                  |
| NANDC_BCHST1        | 0x0024 | W    | 0x000000000 | BCH status register for codeword 2~3                  |
| NANDC_BCHST2        | 0x0028 | W    | 0x000000000 | BCH status register for codeword 4~5                  |
| NANDC_BCHST3        | 0x002c | W    | 0x000000000 | BCH status register for codeword 6~7                  |

| <b>Name</b>     | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>                                        |
|-----------------|---------------|-------------|--------------------|-----------------------------------------------------------|
| NANDC_BCHST4    | 0x0030        | W           | 0x00000000         | BCH status register for codeword 8~9                      |
| NANDC_BCHST5    | 0x0034        | W           | 0x00000000         | BCH status register for codeword 10~11                    |
| NANDC_BCHST6    | 0x0038        | W           | 0x00000000         | BCH status register for codeword 12~13                    |
| NANDC_BCHST7    | 0x003c        | W           | 0x00000000         | BCH status register for codeword 14~15                    |
| NANDC_BCHLOC0   | 0x0040        | W           | 0x00000000         | BCH error bit location number register for codeword 0~5   |
| NANDC_BCHLOC1   | 0x0044        | W           | 0x00000000         | BCH error bit location number register for codeword 6~11  |
| NANDC_BCHLOC2   | 0x0048        | W           | 0x00000000         | BCH error bit location number register for codeword 12~15 |
| NANDC_BCHLOC3   | 0x004c        | W           | 0x00000000         | Highest bit for BCH error bit location number register    |
| NANDC_BCHDE0_0  | 0x0070        | W           | 0x00000000         | BCH decode result of 0th error bit for codeword 0         |
| NANDC_BCHDE0_1  | 0x0074        | W           | 0x00000000         | BCH decode result of 1th error bit for codeword 0         |
| NANDC_BCHDE0_2  | 0x0078        | W           | 0x00000000         | BCH decode result of 2th error bit for codeword 0         |
| NANDC_BCHDE0_3  | 0x007c        | W           | 0x00000000         | BCH decode result of 3th error bit for codeword 0         |
| NANDC_BCHDE0_4  | 0x0080        | W           | 0x00000000         | BCH decode result of 4th error bit for codeword 0         |
| NANDC_BCHDE0_5  | 0x0084        | W           | 0x00000000         | BCH decode result of 5th error bit for codeword 0         |
| NANDC_BCHDE0_6  | 0x0088        | W           | 0x00000000         | BCH decode result of 6th error bit for codeword 0         |
| NANDC_BCHDE0_7  | 0x008c        | W           | 0x00000000         | BCH decode result of 7th error bit for codeword 0         |
| NANDC_BCHDE0_8  | 0x0090        | W           | 0x00000000         | BCH decode result of 8th error bit for codeword 0         |
| NANDC_BCHDE0_9  | 0x0094        | W           | 0x00000000         | BCH decode result of 9th error bit for codeword 0         |
| NANDC_BCHDE0_10 | 0x0098        | W           | 0x00000000         | BCH decode result of 10th error bit for codeword 0        |
| NANDC_BCHDE0_11 | 0x009c        | W           | 0x00000000         | BCH decode result of 11th error bit for codeword 0        |
| NANDC_BCHDE0_12 | 0x00a0        | W           | 0x00000000         | BCH decode result of 12th error bit for codeword 0        |
| NANDC_BCHDE0_13 | 0x00a4        | W           | 0x00000000         | BCH decode result of 13th error bit for codeword 0        |

| <b>Name</b>     | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>                                 |
|-----------------|---------------|-------------|--------------------|----------------------------------------------------|
| NANDC_BCHDE0_14 | 0x00a8        | W           | 0x00000000         | BCH decode result of 14th error bit for codeword 0 |
| NANDC_BCHDE0_15 | 0x00ac        | W           | 0x00000000         | BCH decode result of 15th error bit for codeword 0 |
| NANDC_BCHDE0_16 | 0x00b0        | W           | 0x00000000         | BCH decode result of 16th error bit for codeword 0 |
| NANDC_BCHDE0_17 | 0x00b4        | W           | 0x00000000         | BCH decode result of 17th error bit for codeword 0 |
| NANDC_BCHDE0_18 | 0x00b8        | W           | 0x00000000         | BCH decode result of 18th error bit for codeword 0 |
| NANDC_BCHDE0_19 | 0x00bc        | W           | 0x00000000         | BCH decode result of 19th error bit for codeword 0 |
| NANDC_BCHDE0_20 | 0x00c0        | W           | 0x00000000         | BCH decode result of 20th error bit for codeword 0 |
| NANDC_BCHDE0_21 | 0x00c4        | W           | 0x00000000         | BCH decode result of 21th error bit for codeword 0 |
| NANDC_BCHDE0_22 | 0x00c8        | W           | 0x00000000         | BCH decode result of 22th error bit for codeword 0 |
| NANDC_BCHDE0_23 | 0x00cc        | W           | 0x00000000         | BCH decode result of 23th error bit for codeword 0 |
| NANDC_BCHDE1_0  | 0x00d0        | W           | 0x00000000         | BCH decode result of 0th error bit for codeword 1  |
| NANDC_BCHDE1_1  | 0x00d4        | W           | 0x00000000         | BCH decode result of 1th error bit for codeword 1  |
| NANDC_BCHDE1_2  | 0x00d8        | W           | 0x00000000         | BCH decode result of 2th error bit for codeword 1  |
| NANDC_BCHDE1_3  | 0x00dc        | W           | 0x00000000         | BCH decode result of 3th error bit for codeword 1  |
| NANDC_BCHDE1_4  | 0x00e0        | W           | 0x00000000         | BCH decode result of 4th error bit for codeword 1  |
| NANDC_BCHDE1_5  | 0x00e4        | W           | 0x00000000         | BCH decode result of 5th error bit for codeword 1  |
| NANDC_BCHDE1_6  | 0x00e8        | W           | 0x00000000         | BCH decode result of 6th error bit for codeword 1  |
| NANDC_BCHDE1_7  | 0x00ec        | W           | 0x00000000         | BCH decode result of 7th error bit for codeword 1  |
| NANDC_BCHDE1_8  | 0x00f0        | W           | 0x00000000         | BCH decode result of 8th error bit for codeword 1  |
| NANDC_BCHDE1_9  | 0x00f4        | W           | 0x00000000         | BCH decode result of 9th error bit for codeword 1  |
| NANDC_BCHDE1_10 | 0x00f8        | W           | 0x00000000         | BCH decode result of 10th error bit for codeword 1 |
| NANDC_BCHDE1_11 | 0x00fc        | W           | 0x00000000         | BCH decode result of 11th error bit for codeword 1 |

| <b>Name</b>        | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|--------------------|---------------|-------------|--------------------|------------------------------------------------------|
| NANDC_BCHDE1_12    | 0x0100        | W           | 0x00000000         | BCH decode result of 12th error bit for codeword 1   |
| NANDC_BCHDE1_13    | 0x0104        | W           | 0x00000000         | BCH decode result of 13th error bit for codeword 1   |
| NANDC_BCHDE1_14    | 0x0108        | W           | 0x00000000         | BCH decode result of 14th error bit for codeword 1   |
| NANDC_BCHDE1_15    | 0x010c        | W           | 0x00000000         | BCH decode result of 15th error bit for codeword 1   |
| NANDC_BCHDE1_16    | 0x0110        | W           | 0x00000000         | BCH decode result of 16th error bit for codeword 1   |
| NANDC_BCHDE1_17    | 0x0114        | W           | 0x00000000         | BCH decode result of 17th error bit for codeword 1   |
| NANDC_BCHDE1_18    | 0x0118        | W           | 0x00000000         | BCH decode result of 18th error bit for codeword 1   |
| NANDC_BCHDE1_19    | 0x011c        | W           | 0x00000000         | BCH decode result of 19th error bit for codeword 1   |
| NANDC_BCHDE1_20    | 0x0120        | W           | 0x00000000         | BCH decode result of 20th error bit for codeword 1   |
| NANDC_BCHDE1_21    | 0x0124        | W           | 0x00000000         | BCH decode result of 21th error bit for codeword 1   |
| NANDC_BCHDE1_22    | 0x0128        | W           | 0x00000000         | BCH decode result of 22th error bit for codeword 1   |
| NANDC_BCHDE1_23    | 0x012c        | W           | 0x00000000         | BCH decode result of 23th error bit for codeword 1   |
| NANDC_DLL_CTL_REG0 | 0x0130        | W           | 0x00000000         | DLL control register 0                               |
| NANDC_DLL_CTL_REG1 | 0x0134        | W           | 0x00000000         | DLL control register 1                               |
| NANDC_DLL_OBS_REG0 | 0x0138        | W           | 0x00000002         | DLL status register                                  |
| NANDC_RANDMZ_CFG   | 0x0150        | W           | 0x00000000         | Randomizer configure register                        |
| NANDC_FMWAIT_SYN   | 0x0158        | W           | 0x00000000         | Flash timing control register for synchronous timing |
| NANDC_NANDC_VER    | 0x0160        | W           | 0x56363030         | NandC version register                               |
| NANDC_LLPCONTROL   | 0x0164        | W           | 0x00000000         | LLP control register                                 |
| NANDC_LLPSSTATUS   | 0x0168        | W           | 0x00000001         | LLP status register                                  |
| NANDC_INTEN        | 0x016c        | W           | 0x00000000         | Interrupt enable register                            |
| NANDC_INTCLR       | 0x0170        | W           | 0x00000000         | Interrupt clear register                             |
| NANDC_INTST        | 0x0174        | W           | 0x00000000         | Interrupt status register                            |
| NANDC_SPARE0_0     | 0x0200        | W           | 0xffffffff         | System information for codeword 0                    |
| NANDC_SPARE0_1     | 0x0204        | W           | 0x00000000         | Spare data and BCH encode information for codeword 0 |
| NANDC_SPARE0_2     | 0x0208        | W           | 0x00000000         | Spare data and BCH encode information for codeword 0 |
| NANDC_SPARE0_3     | 0x020c        | W           | 0x00000000         | Spare data and BCH encode information for codeword 0 |

| <b>Name</b>     | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|-----------------|---------------|-------------|--------------------|------------------------------------------------------|
| NANDC_SPARE0_4  | 0x0210        | W           | 0x00000000         | Spare data and BCH encode information for codeword 0 |
| NANDC_SPARE0_5  | 0x0214        | W           | 0x00000000         | Spare data and BCH encode information for codeword 0 |
| NANDC_SPARE0_6  | 0x0218        | W           | 0x00000000         | Spare data and BCH encode information for codeword 0 |
| NANDC_SPARE0_7  | 0x021c        | W           | 0x00000000         | Spare data and BCH encode information for codeword 0 |
| NANDC_SPARE0_8  | 0x0220        | W           | 0x00000000         | Spare data and BCH encode information for codeword 0 |
| NANDC_SPARE0_9  | 0x0224        | W           | 0x00000000         | Spare data and BCH encode information for codeword 0 |
| NANDC_SPARE0_10 | 0x0228        | W           | 0x00000000         | Spare data and BCH encode information for codeword 0 |
| NANDC_SPARE0_11 | 0x022c        | W           | 0x00000000         | Spare data and BCH encode information for codeword 0 |
| NANDC_SPARE1_0  | 0x0230        | W           | 0xffffffff         | System information for codeword 1                    |
| NANDC_SPARE1_1  | 0x0234        | W           | 0x00000000         | Spare data and BCH encode information for codeword 1 |
| NANDC_SPARE1_2  | 0x0238        | W           | 0x00000000         | Spare data and BCH encode information for codeword 1 |
| NANDC_SPARE1_3  | 0x023c        | W           | 0x00000000         | Spare data and BCH encode information for codeword 1 |
| NANDC_SPARE1_4  | 0x0240        | W           | 0x00000000         | Spare data and BCH encode information for codeword 1 |
| NANDC_SPARE1_5  | 0x0244        | W           | 0x00000000         | Spare data and BCH encode information for codeword 1 |
| NANDC_SPARE1_6  | 0x0248        | W           | 0x00000000         | Spare data and BCH encode information for codeword 1 |
| NANDC_SPARE1_7  | 0x024c        | W           | 0x00000000         | Spare data and BCH encode information for codeword 1 |
| NANDC_SPARE1_8  | 0x0250        | W           | 0x00000000         | Spare data and BCH encode information for codeword 1 |
| NANDC_SPARE1_9  | 0x0254        | W           | 0x00000000         | Spare data and BCH encode information for codeword 1 |
| NANDC_SPARE1_10 | 0x0258        | W           | 0x00000000         | Spare data and BCH encode information for codeword 1 |
| NANDC_SPARE1_11 | 0x025c        | W           | 0x00000000         | Spare data and BCH encode information for codeword 1 |
| NANDC_SPARE0_12 | 0x0260        | W           | 0x00000000         | Spare data and BCH encode information for codeword 0 |
| NANDC_SPARE0_13 | 0x0264        | W           | 0x00000000         | Spare data and BCH encode information for codeword 0 |
| NANDC_SPARE0_14 | 0x0268        | W           | 0x00000000         | Spare data and BCH encode information for codeword 0 |

| Name            | Offset | Size | Reset Value | Description                                          |
|-----------------|--------|------|-------------|------------------------------------------------------|
| NANDC_SPARE0_15 | 0x026c | W    | 0x00000000  | Spare data and BCH encode information for codeword 0 |
| NANDC_SPARE0_16 | 0x0270 | W    | 0x00000000  | Spare data and BCH encode information for codeword 0 |
| NANDC_SPARE0_17 | 0x0274 | W    | 0x00000000  | Spare data and BCH encode information for codeword 0 |
| NANDC_SPARE0_18 | 0x0278 | W    | 0x00000000  | Spare data and BCH encode information for codeword 0 |
| NANDC_SPARE0_19 | 0x027c | W    | 0x00000000  | Spare data and BCH encode information for codeword 0 |
| NANDC_SPARE0_20 | 0x0280 | W    | 0x00000000  | Spare data and BCH encode information for codeword 0 |
| NANDC_SPARE0_21 | 0x0284 | W    | 0x00000000  | Spare data and BCH encode information for codeword 0 |
| NANDC_SPARE0_22 | 0x0288 | W    | 0x00000000  | Spare data and BCH encode information for codeword 0 |
| NANDC_SPARE0_23 | 0x028c | W    | 0x00000000  | Spare data and BCH encode information for codeword 0 |
| NANDC_SPARE0_24 | 0x0290 | W    | 0x00000000  | Spare data and BCH encode information for codeword 0 |
| NANDC_SPARE0_25 | 0x0294 | W    | 0x00000000  | Spare data and BCH encode information for codeword 0 |
| NANDC_SPARE0_26 | 0x0298 | W    | 0x00000000  | Spare data and BCH encode information for codeword 0 |
| NANDC_SPARE0_27 | 0x029c | W    | 0x00000000  | Spare data and BCH encode information for codeword 0 |
| NANDC_SPARE1_12 | 0x02a0 | W    | 0x00000000  | Spare data and BCH encode information for codeword 1 |
| NANDC_SPARE1_13 | 0x02a4 | W    | 0x00000000  | Spare data and BCH encode information for codeword 1 |
| NANDC_SPARE1_14 | 0x02a8 | W    | 0x00000000  | Spare data and BCH encode information for codeword 1 |
| NANDC_SPARE1_15 | 0x02ac | W    | 0x00000000  | Spare data and BCH encode information for codeword 1 |
| NANDC_SPARE1_16 | 0x02b0 | W    | 0x00000000  | Spare data and BCH encode information for codeword 1 |
| NANDC_SPARE1_17 | 0x02b4 | W    | 0x00000000  | Spare data and BCH encode information for codeword 1 |
| NANDC_SPARE1_18 | 0x02b8 | W    | 0x00000000  | Spare data and BCH encode information for codeword 1 |
| NANDC_SPARE1_19 | 0x02bc | W    | 0x00000000  | Spare data and BCH encode information for codeword 1 |
| NANDC_SPARE1_20 | 0x02c0 | W    | 0x00000000  | Spare data and BCH encode information for codeword 1 |

| <b>Name</b>     | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|-----------------|---------------|-------------|--------------------|------------------------------------------------------|
| NANDC_SPARE1_21 | 0x02c4        | W           | 0x00000000         | Spare data and BCH encode information for codeword 1 |
| NANDC_SPARE1_22 | 0x02c8        | W           | 0x00000000         | Spare data and BCH encode information for codeword 1 |
| NANDC_SPARE1_23 | 0x02cc        | W           | 0x00000000         | Spare data and BCH encode information for codeword 1 |
| NANDC_SPARE1_24 | 0x02d0        | W           | 0x00000000         | Spare data and BCH encode information for codeword 1 |
| NANDC_SPARE1_25 | 0x02d4        | W           | 0x00000000         | Spare data and BCH encode information for codeword 1 |
| NANDC_SPARE1_26 | 0x02d8        | W           | 0x00000000         | Spare data and BCH encode information for codeword 1 |
| NANDC_SPARE1_27 | 0x02dc        | W           | 0x00000000         | Spare data and BCH encode information for codeword 1 |
| NANDC_BCHDE0_24 | 0x0400        | W           | 0x00000000         | BCH decode result of 24th error bit for codeword 0   |
| NANDC_BCHDE0_25 | 0x0404        | W           | 0x00000000         | BCH decode result of 25th error bit for codeword 0   |
| NANDC_BCHDE0_26 | 0x0408        | W           | 0x00000000         | BCH decode result of 26th error bit for codeword 0   |
| NANDC_BCHDE0_27 | 0x040c        | W           | 0x00000000         | BCH decode result of 27th error bit for codeword 0   |
| NANDC_BCHDE0_28 | 0x0410        | W           | 0x00000000         | BCH decode result of 28th error bit for codeword 0   |
| NANDC_BCHDE0_29 | 0x0414        | W           | 0x00000000         | BCH decode result of 29th error bit for codeword 0   |
| NANDC_BCHDE0_30 | 0x0418        | W           | 0x00000000         | BCH decode result of 30th error bit for codeword 0   |
| NANDC_BCHDE0_31 | 0x041c        | W           | 0x00000000         | BCH decode result of 31th error bit for codeword 0   |
| NANDC_BCHDE0_32 | 0x0420        | W           | 0x00000000         | BCH decode result of 32th error bit for codeword 0   |
| NANDC_BCHDE0_33 | 0x0424        | W           | 0x00000000         | BCH decode result of 33th error bit for codeword 0   |
| NANDC_BCHDE0_34 | 0x0428        | W           | 0x00000000         | BCH decode result of 34th error bit for codeword 0   |
| NANDC_BCHDE0_35 | 0x042c        | W           | 0x00000000         | BCH decode result of 35th error bit for codeword 0   |
| NANDC_BCHDE0_36 | 0x0430        | W           | 0x00000000         | BCH decode result of 36th error bit for codeword 0   |
| NANDC_BCHDE0_37 | 0x0434        | W           | 0x00000000         | BCH decode result of 37th error bit for codeword 0   |
| NANDC_BCHDE0_38 | 0x0438        | W           | 0x00000000         | BCH decode result of 38th error bit for codeword 0   |

| <b>Name</b>     | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>                                 |
|-----------------|---------------|-------------|--------------------|----------------------------------------------------|
| NANDC_BCHDE0_39 | 0x043c        | W           | 0x00000000         | BCH decode result of 39th error bit for codeword 0 |
| NANDC_BCHDE0_40 | 0x0440        | W           | 0x00000000         | BCH decode result of 40th error bit for codeword 0 |
| NANDC_BCHDE0_41 | 0x0444        | W           | 0x00000000         | BCH decode result of 41th error bit for codeword 0 |
| NANDC_BCHDE0_42 | 0x0448        | W           | 0x00000000         | BCH decode result of 42th error bit for codeword 0 |
| NANDC_BCHDE0_43 | 0x044c        | W           | 0x00000000         | BCH decode result of 43th error bit for codeword 0 |
| NANDC_BCHDE0_44 | 0x0450        | W           | 0x00000000         | BCH decode result of 44th error bit for codeword 0 |
| NANDC_BCHDE0_45 | 0x0454        | W           | 0x00000000         | BCH decode result of 45th error bit for codeword 0 |
| NANDC_BCHDE0_46 | 0x0458        | W           | 0x00000000         | BCH decode result of 46th error bit for codeword 0 |
| NANDC_BCHDE0_47 | 0x045c        | W           | 0x00000000         | BCH decode result of 47th error bit for codeword 0 |
| NANDC_BCHDE0_48 | 0x0460        | W           | 0x00000000         | BCH decode result of 48th error bit for codeword 0 |
| NANDC_BCHDE0_49 | 0x0464        | W           | 0x00000000         | BCH decode result of 49th error bit for codeword 0 |
| NANDC_BCHDE0_50 | 0x0468        | W           | 0x00000000         | BCH decode result of 50th error bit for codeword 0 |
| NANDC_BCHDE0_51 | 0x046c        | W           | 0x00000000         | BCH decode result of 51th error bit for codeword 0 |
| NANDC_BCHDE0_52 | 0x0470        | W           | 0x00000000         | BCH decode result of 52th error bit for codeword 0 |
| NANDC_BCHDE0_53 | 0x0474        | W           | 0x00000000         | BCH decode result of 53th error bit for codeword 0 |
| NANDC_BCHDE0_54 | 0x0478        | W           | 0x00000000         | BCH decode result of 54th error bit for codeword 0 |
| NANDC_BCHDE0_55 | 0x047c        | W           | 0x00000000         | BCH decode result of 55th error bit for codeword 0 |
| NANDC_BCHDE0_56 | 0x0480        | W           | 0x00000000         | BCH decode result of 56th error bit for codeword 0 |
| NANDC_BCHDE0_57 | 0x0484        | W           | 0x00000000         | BCH decode result of 57th error bit for codeword 0 |
| NANDC_BCHDE0_58 | 0x0488        | W           | 0x00000000         | BCH decode result of 58th error bit for codeword 0 |
| NANDC_BCHDE0_59 | 0x048c        | W           | 0x00000000         | BCH decode result of 59th error bit for codeword 0 |
| NANDC_BCHDE1_24 | 0x0490        | W           | 0x00000000         | BCH decode result of 24th error bit for codeword 1 |

| <b>Name</b>     | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>                                 |
|-----------------|---------------|-------------|--------------------|----------------------------------------------------|
| NANDC_BCHDE1_25 | 0x0494        | W           | 0x00000000         | BCH decode result of 25th error bit for codeword 1 |
| NANDC_BCHDE1_26 | 0x0498        | W           | 0x00000000         | BCH decode result of 26th error bit for codeword 1 |
| NANDC_BCHDE1_27 | 0x049c        | W           | 0x00000000         | BCH decode result of 27th error bit for codeword 1 |
| NANDC_BCHDE1_28 | 0x04a0        | W           | 0x00000000         | BCH decode result of 28th error bit for codeword 1 |
| NANDC_BCHDE1_29 | 0x04a4        | W           | 0x00000000         | BCH decode result of 29th error bit for codeword 1 |
| NANDC_BCHDE1_30 | 0x04a8        | W           | 0x00000000         | BCH decode result of 30th error bit for codeword 1 |
| NANDC_BCHDE1_31 | 0x04ac        | W           | 0x00000000         | BCH decode result of 31th error bit for codeword 1 |
| NANDC_BCHDE1_32 | 0x04b0        | W           | 0x00000000         | BCH decode result of 32th error bit for codeword 1 |
| NANDC_BCHDE1_33 | 0x04b4        | W           | 0x00000000         | BCH decode result of 33th error bit for codeword 1 |
| NANDC_BCHDE1_34 | 0x04b8        | W           | 0x00000000         | BCH decode result of 34th error bit for codeword 1 |
| NANDC_BCHDE1_35 | 0x04bc        | W           | 0x00000000         | BCH decode result of 35th error bit for codeword 1 |
| NANDC_BCHDE1_36 | 0x04c0        | W           | 0x00000000         | BCH decode result of 36th error bit for codeword 1 |
| NANDC_BCHDE1_37 | 0x04c4        | W           | 0x00000000         | BCH decode result of 37th error bit for codeword 1 |
| NANDC_BCHDE1_38 | 0x04c8        | W           | 0x00000000         | BCH decode result of 38th error bit for codeword 1 |
| NANDC_BCHDE1_39 | 0x04cc        | W           | 0x00000000         | BCH decode result of 39th error bit for codeword 1 |
| NANDC_BCHDE1_40 | 0x04d0        | W           | 0x00000000         | BCH decode result of 40th error bit for codeword 1 |
| NANDC_BCHDE1_41 | 0x04d4        | W           | 0x00000000         | BCH decode result of 41th error bit for codeword 1 |
| NANDC_BCHDE1_42 | 0x04d8        | W           | 0x00000000         | BCH decode result of 42th error bit for codeword 1 |
| NANDC_BCHDE1_43 | 0x04dc        | W           | 0x00000000         | BCH decode result of 43th error bit for codeword 1 |
| NANDC_BCHDE1_44 | 0x04e0        | W           | 0x00000000         | BCH decode result of 44th error bit for codeword 1 |
| NANDC_BCHDE1_45 | 0x04e4        | W           | 0x00000000         | BCH decode result of 45th error bit for codeword 1 |
| NANDC_BCHDE1_46 | 0x04e8        | W           | 0x00000000         | BCH decode result of 46th error bit for codeword 1 |

| Name            | Offset | Size | Reset Value | Description                                        |
|-----------------|--------|------|-------------|----------------------------------------------------|
| NANDC_BCHDE1_47 | 0x04ec | W    | 0x00000000  | BCH decode result of 47th error bit for codeword 1 |
| NANDC_BCHDE1_48 | 0x04f0 | W    | 0x00000000  | BCH decode result of 48th error bit for codeword 1 |
| NANDC_BCHDE1_49 | 0x04f4 | W    | 0x00000000  | BCH decode result of 49th error bit for codeword 1 |
| NANDC_BCHDE1_50 | 0x04f8 | W    | 0x00000000  | BCH decode result of 50th error bit for codeword 1 |
| NANDC_BCHDE1_51 | 0x04fc | W    | 0x00000000  | BCH decode result of 51th error bit for codeword 1 |
| NANDC_BCHDE1_52 | 0x0500 | W    | 0x00000000  | BCH decode result of 52th error bit for codeword 1 |
| NANDC_BCHDE1_53 | 0x0504 | W    | 0x00000000  | BCH decode result of 53th error bit for codeword 1 |
| NANDC_BCHDE1_54 | 0x0508 | W    | 0x00000000  | BCH decode result of 54th error bit for codeword 1 |
| NANDC_BCHDE1_55 | 0x050c | W    | 0x00000000  | BCH decode result of 55th error bit for codeword 1 |
| NANDC_BCHDE1_56 | 0x0510 | W    | 0x00000000  | BCH decode result of 56th error bit for codeword 1 |
| NANDC_BCHDE1_57 | 0x0514 | W    | 0x00000000  | BCH decode result of 57th error bit for codeword 1 |
| NANDC_BCHDE1_58 | 0x0518 | W    | 0x00000000  | BCH decode result of 58th error bit for codeword 1 |
| NANDC_BCHDE1_59 | 0x051c | W    | 0x00000000  | BCH decode result of 59th error bit for codeword 1 |

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

#### 7.4.3 Detail Register Description

##### NANDC\_FMCTL

Address: Operational Base + offset (0x0000)

Flash interface control register

| Bit   | Attr | Reset Value | Description                                                                                                                                                                      |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RO   | 0x0         | reserved                                                                                                                                                                         |
| 15    | RW   | 0x0         | <p>syn_mode<br/>Toggle enable signal, 1 active.<br/>1'b0: ONFI synchronous flash<br/>1'b1: Toggle synchronous flash</p>                                                          |
| 14    | RW   | 0x0         | <p>syn_ciken<br/>Synchronous flash clock enable signal, 1 active.<br/>Only available in Synchronous Mode.<br/>1'b0: flash clock is disabled<br/>1'b1: flash clock is enabled</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13         | RW          | 0x0                | tm<br>Timing mode indication.<br>1'b0: Asynchronous Mode<br>1'b1: Synchronous Mode (Toggle or ONFI Synchronous)                                                                      |
| 12         | RW          | 0x0                | dwidth<br>Flash data bus width indication.<br>1'b0: 8bits, active in both Asynchronous Mode flash and Synchronous Mode flash<br>1'b1: 16bits, active only in Asynchronous Mode flash |
| 11:10      | RO          | 0x0                | reserved                                                                                                                                                                             |
| 9          | RO          | 0x1                | frdy<br>Flash ready/busy indicate signal.<br>1'b0: flash is busy<br>1'b1: flash is ready<br>This bit is the sample of the pin of R/Bn.                                               |
| 8          | RW          | 0x0                | wp<br>Flash write protect.<br>1'b0: flash program/erase disabled.<br>1'b1: flash program/erase enabled.<br>This bit is output to the pin of WPn.                                     |
| 7          | RW          | 0x0                | fcs7<br>Flash memory chip 7 select control.<br>1'b1: hold flash memory chip select activity<br>1'b0: flash memory chip select activity free                                          |
| 6          | RW          | 0x0                | fcs6<br>Flash memory chip 6 select control.<br>1'b1: hold flash memory chip select activity.<br>1'b0: flash memory chip select activity free.                                        |
| 5          | RW          | 0x0                | fcs5<br>Flash memory chip 5 select control.<br>1'b1: hold flash memory chip select activity<br>1'b0: flash memory chip select activity free                                          |
| 4          | RW          | 0x0                | fcs4<br>Flash memory chip 4 select control.<br>1'b1: hold flash memory chip select activity<br>1'b0: flash memory chip select activity free                                          |
| 3          | RW          | 0x0                | fcs3<br>Flash memory chip 3 select control.<br>1'b1: hold flash memory chip select activity<br>1'b0: flash memory chip select activity free                                          |
| 2          | RW          | 0x0                | fcs2<br>Flash memory chip 2 select control.<br>1'b1: hold flash memory chip select activity<br>1'b0: flash memory chip select activity free                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| 1          | RW          | 0x0                | fcs1<br>Flash memory chip 1 select control.<br>1'b1: hold flash memory chip select activity<br>1'b0: flash memory chip select activity free |
| 0          | RW          | 0x0                | fcs0<br>Flash memory chip 0 select control.<br>1'b1: hold flash memory chip select activity<br>1'b0: flash memory chip select activity free |

**NANDC\_FMWAIT\_ASYN**

Address: Operational Base + offset (0x0004)

Flash timing control register for asynchronous timing

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RO          | 0x0                | reserved                                                                                                                                                                                                                  |
| 30         | RW          | 0x0                | fmw_dly_en<br>fmw_dly enable signal,1 active                                                                                                                                                                              |
| 29:24      | RW          | 0x3f               | fmw_dly<br>The number of delay cycle between two codeword transmission                                                                                                                                                    |
| 23:18      | RO          | 0x0                | reserved                                                                                                                                                                                                                  |
| 17:12      | RW          | 0x3f               | csr_w<br>When in Asynchronous mode or Toggle address/command mode, this field specifies the number of processor clock cycles from the falling edge of CSn to the falling edge of RDn or WRn. The min value of csr_w is 0. |
| 11         | RW          | 0x0                | hard_rdy<br>Hardware handshaking controller bit.<br>When asserted, an external device asserts signal "RDY" to extend a wait-state access and the rest bits in this register will be ignored                               |
| 10:5       | RW          | 0x3f               | rwpw<br>When in Asynchronous mode or Toggle address/command mode, this field specifies the width of RDn or WRn in processor clock cycles, $0x0 \leq rwpw \leq 0x3f$ .                                                     |
| 4:0        | RW          | 0x1f               | rwcs<br>When in Asynchronous mode or Toggle address/command mode, this field specifies the number of processor clock cycles from the rising edge of RDn or WRn to the rising edge of CSn, $0x0 \leq rwcs \leq 0x1f$ .     |

**NANDC\_FLCTL**

Address: Operational Base + offset (0x0008)

Internal transfer control 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:22      | RW          | 0x00               | <p>page_num<br/>Transmission codeword number in internal DMA mode when bus-mode is master-mode.<br/>1~16: 1~16 codeword<br/>default: not support<br/>Only active in internal DMA mode and when bus-mode is master-mode</p>                                                                                                                                                                           |
| 21         | RW          | 0x0                | <p>page_size<br/>Transmission codeword size in internal DMA mode.<br/>1'b0: 1024bytes/codeword<br/>1'b1: 512bytes/codeword</p>                                                                                                                                                                                                                                                                       |
| 20         | RO          | 0x1                | <p>tr_rdy<br/>Internal DMA transmission ready indication.<br/>1'b0: internal DMA transmission is busy<br/>1'b1: internal DMA transmission is ready<br/>When reading flash, tr_rdy should not be set to 1 until all data transmission and correct finished.<br/>When programming flash, tr_rdy should not be set to 1 until all data transmission finished.<br/>Only active in internal DMA mode.</p> |
| 19         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                             |
| 18:12      | RW          | 0x00               | <p>spare_size<br/>Spare byte number when lba_en=1.<br/>0&lt;= spare_size&lt;=109.<br/>When spare_size&gt;=109, it is treated as 0.<br/>The spare_size must be even number when flash is ONFI Synchronous Flash or Asynchronous Flash with 16bits data width.</p>                                                                                                                                     |
| 11         | RW          | 0x0                | <p>lba_en<br/>LBA mode indication, 1 active.<br/>1'b0: NO-LBA mode, NandC should transfer both page data and spare data in every codeword<br/>1'b1: LBA mode, NandC should transfer both page data and spare data in every codeword<br/>When lba_en is active, BCH CODEC should be disabled, spare_size and page_size are configurable.<br/>When lba_en is active, cor_able is inactive.</p>         |
| 10         | RW          | 0x0                | <p>cor_able<br/>Auto correct enable indication, 1 active.<br/>1'b0: auto correct disable<br/>1'b1: auto correct enable<br/>Only active in internal DMA mode. lba_en is prior to cor_able. When lba_en=1, cor_able is ignored.</p>                                                                                                                                                                    |
| 9:8        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                             |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7          | RW          | 0x0                | <p>flash_st_mod<br/>Mode for NandC to start internal data transmission in internal DMA mode.</p> <p>1'b0: busy mode, hardware should not start internal data transmission until flash is ready even flash_st is asserted</p> <p>1'b1: ready mode, hardware should start internal data transmission directly when flash_st is asserted</p> <p>Only active in internal DMA mode.</p> |
| 6:5        | RW          | 0x0                | <p>tr_count<br/>Transmission codeword number in internal DMA mode when bus-mode is slave-mode.</p> <p>2'b00: 0 codeword need transferred</p> <p>2'b01: 1 codeword need transferred</p> <p>2'b10: 2 codeword need transferred</p> <p>2'b11: not supported</p> <p>Only active in internal DMA mode and when bus-mode is slave-mode.</p>                                              |
| 4          | RW          | 0x0                | <p>st_addr<br/>Start buffer address.</p> <p>1'b0: start transfer from sram0</p> <p>1'b1: start transfer from sram1</p> <p>Bear in mind only active in internal DMA mode.</p>                                                                                                                                                                                                       |
| 3          | RW          | 0x0                | <p>bypass<br/>NandC internal DMA bypass indication.</p> <p>1'b0: bypass the internal DMA, data are transferred to/from flash by direct path</p> <p>1'b1: internal DMA active, data are transferred to/from flash by internal DMA</p>                                                                                                                                               |
| 2          | RW          | 0x0                | <p>flash_st<br/>Start signal for NandC to transfer data between flash and internal buffer in internal DMA mode. When asserted, it will auto cleared.</p> <p>1'b0: not start transmission</p> <p>1'b1: start transmission</p> <p>Bear in mind that it is only active in internal DMA mode</p>                                                                                       |
| 1          | RW          | 0x0                | <p>flash_rdn<br/>Indicate data flow direction.</p> <p>1'b0: NandC read data from flash</p> <p>1'b1: NandC write data to flash</p>                                                                                                                                                                                                                                                  |
| 0          | RW          | 0x0                | <p>flash_RST<br/>NandC software reset indication. When asserted, it will auto cleared.</p> <p>1'b0: not software reset</p> <p>1'b1: software reset</p> <p>Bear in mind that flash_RST is prior to flash_st</p>                                                                                                                                                                     |

**NANDC\_BCHCTL**

Address: Operational Base + offset (0x000c)

BCH control register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:27      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                  |
| 26:19      | RW          | 0x00               | bchthres<br>BCH error number threshold                                                                                                                                                                                                                                                                                                                                                                    |
| 18         | RW          | 0x0                | bchmode1<br>BCH mode selection bit 1.<br>BchMode=bchmode1, bchmode0:<br>2'b00: 16bitBCH<br>2'b01: 24bitBCH<br>2'b10: 40bitBCH<br>2'b11: 60bitBCH                                                                                                                                                                                                                                                          |
| 17         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                  |
| 16         | RW          | 0x0                | bchpage<br>The data size indication when BCH is active.<br>1'b0: 1024 bytes, all the 1024 bytes data in codeword are valid data to be transferred<br>1'b1: 512 bytes, 1th~512th bytes in codeword are valid data to be transferred, and 513th~1024th bytes in codeword are invalid data stuffed with 0xff<br>Only active when data transferred in internal DMA mode and for asynchronous flash.           |
| 15:8       | RW          | 0x00               | addr<br>BCH active range selection.<br>BCH should be active when access in range address.                                                                                                                                                                                                                                                                                                                 |
| 7:5        | RW          | 0x0                | region<br>BCH active region selection indication.<br>3'b000: Flash memory 0 region (flash 0)<br>3'b001: Flash memory 1 region (flash 1)<br>3'b010: Flash memory 2 region (flash 2)<br>3'b011: Flash memory 3 region (flash 3)<br>3'b100: Flash memory 4 region (flash 4)<br>3'b101: Flash memory 5 region (flash 5)<br>3'b110: Flash memory 6 region (flash 6)<br>3'b111: Flash memory 7 region (flash 7) |
| 4          | RW          | 0x0                | bchmode0<br>BCH mode selection bit 0.                                                                                                                                                                                                                                                                                                                                                                     |
| 3          | RW          | 0x1                | bchepd<br>BCH encoder/decoder power down indication.<br>1'b0: BCH encoder/decoder working<br>1'b1: BCH encoder/decoder not working                                                                                                                                                                                                                                                                        |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2          | RW          | 0x0                | mode_addrctrl<br>BCH address care mode selection indication.<br>1'b0: address care<br>1'b1: address not care<br>This bit is just active for data transmission in bypass mode, but not for command and address transmission.                                                     |
| 1          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                        |
| 0          | RW          | 0x0                | bchrst<br>BCH software reset indication, When asserted, it will auto cleared.<br>1'b0: not software reset<br>1'b1: software reset<br>BCH Decoder should be software reset before decode begin.<br>BCH software reset should be used with nandc software reset at the same time. |

**NANDC\_MTRANS\_CFG**

Address: Operational Base + offset (0x0010)

Bus transfer configuration register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                               |
| 15         | W1C         | 0x0                | ahb_rst<br>ahb master interface software reset, auto cleared                                                                                                                                                                                                                                                                                                           |
| 14         | RW          | 0x0                | fl_pwd<br>Flash power down indication, 1 active.<br>1'b0: Flash power on, data transferred through master interface is data that to be written into or read from flash<br>1'b1: Flash power down, data transferred through master interface is not data that to be written into or read from flash. NandC is just used as DMA for external memory and internal memory. |
| 13:9       | RW          | 0x00               | incr_num<br>AHB Master incr num indication.<br>When burst=001, software should configure incr_num.<br>Only active for master-mode.                                                                                                                                                                                                                                     |
| 8:6        | RW          | 0x7                | burst<br>AHB Master burst type indication:<br>3'b000: Single transfer<br>3'b011: 4-beat burst<br>3'b101: 8-beat Burst<br>3'b111: 16-beat burst<br>default: not supported<br>Only active for master-mode.                                                                                                                                                               |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-----|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5:3 | RW   | 0x2         | hsize<br>AHB Master data size indication:<br>3'b000: 8 bits<br>3'b001: 16 bits<br>3'b010: 32 bits<br>default: not supported<br>Only active for master-mode.                                                                                                                                                                                                                                                                                                                            |
| 2   | RW   | 0x0         | bus_mode<br>Bus interface selection.<br>1'b0: Slave interface, flash data is transferred through slave interface<br>1'b1: Master interface, flash data is transferred through master interface                                                                                                                                                                                                                                                                                         |
| 1   | RW   | 0x0         | ahb_wr<br>Data transfer direction through master interface.<br>1'b0: read direction(internal memory ->external memory)<br>1'b1: write direction (internal memory->external memory)<br>Only active for master-mode.<br>When read flash(flash_rdn=0), ahb_wr=1; when program flash(flash_rdn=1), ahb_wr=0.                                                                                                                                                                               |
| 0   | W1C  | 0x0         | ahb_wr_st<br>Start indication for loading data from external memory to internal memory or storing data from internal memory to external memory through master. When asserted, it will auto cleared.<br>Notes:<br>a. Only active for master-mode and fl_pwd=1.<br>b. When fl_pwd=0, flash is active, NandC start to transfer data through master interface if flash_st=1<br>c. When fl_pwd=1, flash is not active, NandC start to transfer data through master interface if ahb_wr_st=1 |

**NANDC\_MTRANS\_SADDR0**

Address: Operational Base + offset (0x0014)

Start address register for page data transfer

| Bit  | Attr | Reset Value | Description                                                                                                 |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | saddr0<br>Start address for page data transmission.<br>Only active for master-mode, should be word aligned. |

**NANDC\_MTRANS\_SADDR1**

Address: Operational Base + offset (0x0018)

Start address register for spare data transfer

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | saddr1<br>Start address for spare data.<br>Only active for master-mode, and should be word aligned. |

**NANDC\_MTRANS\_STAT**

Address: Operational Base + offset (0x001c)

Bus transfer status register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                               |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:21      | RO          | 0x0                | reserved                                                                                                                                                         |
| 20:16      | RO          | 0x00               | mtrans_cnt<br>finished counter for codeword transmission through Master interface.<br>Only active for master-mode.                                               |
| 15:0       | RO          | 0x0000             | bus_err<br>Bus error indication for codeword0~15.<br>[0] : bus error for codeword 0<br>.....<br>[15] : bus error for codeword 15<br>Only active for master-mode. |

**NANDC\_BCHST0**

Address: Operational Base + offset (0x0020)

BCH status register for codeword 0~1

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RO          | 0x0                | reserved                                                                                                                                 |
| 30         | RO          | 0x0                | err_hnum1_h1<br>Highest bit of err_hnum1.                                                                                                |
| 29         | RO          | 0x0                | err_tnum1_h1<br>Highest bit of err_tnum1.                                                                                                |
| 28         | RO          | 0x0                | err_hnum0_h1<br>Highest bit of err_hnum0.                                                                                                |
| 27         | RO          | 0x0                | err_tnum0_h1<br>Highest bit of err_tnum0.                                                                                                |
| 26         | RO          | 0x1                | bchrdy<br>Ready indication for bch encoder/decoder, 1 active.<br>1'b0: bch encoder/decoder is busy<br>1'b1: bch encoder/decoder is ready |
| 25:21      | RO          | 0x00               | err_hnum1_l5<br>Lower 5 bits of number of error bits found in first 512bytes of 1st backup codeword.                                     |
| 20:16      | RO          | 0x00               | err_tnum1_l5<br>Lower 5 bits of number of error bits found in 1st backup codeword.                                                       |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------|
| 15         | RO          | 0x0                | fail1<br>Indication for the 1st backup codeword decoded failed or not.<br>1'b0: decode successfully<br>1'b1: decode fail |
| 14         | RO          | 0x0                | done1<br>Indication for finishing decoding the 1st backup codeword.<br>1'b0: not finished<br>1'b1: finished              |
| 13         | RO          | 0x0                | errf1<br>Indication for error found in 1st backup codeword.<br>1'b0: no error<br>1'b1: error found                       |
| 12:8       | RO          | 0x00               | err_hnum0_l5<br>Lower 5 bits of number of error bits found in first 512bytes of current backup codeword.                 |
| 7:3        | RO          | 0x00               | err_tnum0_l5<br>Lower 5 bits of number of error bits found in current backup codeword.                                   |
| 2          | RO          | 0x0                | fail0<br>Indication for current backup codeword decode failed or not.<br>1'b0: decode successfully<br>1'b1: decode fail  |
| 1          | RO          | 0x0                | done0<br>Indication for finishing decoding the current backup codeword.<br>1'b0: not finished<br>1'b1: finished          |
| 0          | RO          | 0x0                | errf0<br>Indication for error found in current backup codeword.<br>1'b0: no error<br>1'b1: error found                   |

**NANDC\_BCHST1**

Address: Operational Base + offset (0x0024)

BCH status register for codeword 2~3

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                        |
|------------|-------------|--------------------|-------------------------------------------|
| 31         | RO          | 0x0                | reserved                                  |
| 30         | RO          | 0x0                | err_hnum3_h1<br>Highest bit of err_hnum3. |
| 29         | RO          | 0x0                | err_tnum3_h1<br>Highest bit of err_tnum3. |
| 28         | RO          | 0x0                | err_hnum2_h1<br>Highest bit of err_hnum2. |
| 27         | RO          | 0x0                | err_tnum2_h1<br>Highest bit of err_tnum2. |
| 26         | RO          | 0x0                | reserved                                  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------|
| 25:21      | RO          | 0x00               | err_hnum3_l5<br>Lower 5 bits of number of error bits found in first 512bytes of 3th backup codeword.                     |
| 20:16      | RO          | 0x00               | err_tnum3_l5<br>Lower 5 bits of number of error bits found in 3th backup codeword.                                       |
| 15         | RO          | 0x0                | fail3<br>Indication for the 3th backup codeword decoded failed or not.<br>1'b0: decode successfully<br>1'b1: decode fail |
| 14         | RO          | 0x0                | done3<br>Indication for finishing decoding the 3th backup codeword.<br>1'b0: not finished<br>1'b1: finished              |
| 13         | RO          | 0x0                | errf3<br>Indication for error found in 3th backup codeword.<br>1'b0: no error<br>1'b1: error found                       |
| 12:8       | RO          | 0x00               | err_hnum2_l5<br>Lower 5 bits of number of error bits found in first 512bytes of 2th backup codeword.                     |
| 7:3        | RO          | 0x00               | err_tnum2_l5<br>Lower 5 bits of number of error bits found in 2th backup codeword.                                       |
| 2          | RO          | 0x0                | fail2<br>Indication for 2th backup codeword decode failed or not.<br>1'b0: decode successfully<br>1'b1: decode fail      |
| 1          | RO          | 0x0                | done2<br>Indication for finishing decoding the 2th backup codeword.<br>1'b0: not finished<br>1'b1: finished              |
| 0          | RO          | 0x0                | errf2<br>Indication for error found in 2th backup codeword.<br>1'b0: no error<br>1'b1: error found                       |

**NANDC\_BCHST2**

Address: Operational Base + offset (0x0028)

BCH status register for codeword 4~5

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | bchst_cwd4_cwd5<br>BCHST information for 4th and 5th backup codeword.<br>Bit assignment is similar to BCHST1 register.<br>For more description, please refer to BCHST1 register. |

**NANDC\_BCHST3**

Address: Operational Base + offset (0x002c)

BCH status register for codeword 6~7

| Bit  | Attr | Reset Value | Description                                                                                                                                                                      |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | bchst_cwd6_cwd7<br>BCHST information for 6th and 7th backup codeword.<br>Bit assignment is similar to BCHST1 register.<br>For more description, please refer to BCHST1 register. |

#### NANDC\_BCHST4

Address: Operational Base + offset (0x0030)

BCH status register for codeword 8~9

| Bit  | Attr | Reset Value | Description                                                                                                                                                                      |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | bchst_cwd8_cwd9<br>BCHST information for 8th and 9th backup codeword.<br>Bit assignment is similar to BCHST1 register.<br>For more description, please refer to BCHST1 register. |

#### NANDC\_BCHST5

Address: Operational Base + offset (0x0034)

BCH status register for codeword 10~11

| Bit  | Attr | Reset Value | Description                                                                                                                                                                          |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | bchst_cwd10_cwd11<br>BCHST information for 10th and 11th backup codeword.<br>Bit assignment is similar to BCHST1 register.<br>For more description, please refer to BCHST1 register. |

#### NANDC\_BCHST6

Address: Operational Base + offset (0x0038)

BCH status register for codeword 12~13

| Bit  | Attr | Reset Value | Description                                                                                                                                                                          |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | bchst_cwd12_cwd13<br>BCHST information for 12th and 13th backup codeword.<br>Bit assignment is similar to BCHST1 register.<br>For more description, please refer to BCHST1 register. |

#### NANDC\_BCHST7

Address: Operational Base + offset (0x003c)

BCH status register for codeword 14~15

| Bit  | Attr | Reset Value | Description                                                                                                                                                                          |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | bchst_cwd14_cwd15<br>BCHST information for 14th and 15th backup codeword.<br>Bit assignment is similar to BCHST1 register.<br>For more description, please refer to BCHST1 register. |

#### NANDC\_BCHLOCO

Address: Operational Base + offset (0x0040)

BCH error bit location number register for codeword 0~5

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                                                                |
| 29:25      | RO          | 0x00               | err_loc5_I5<br>Lower 5 bits of number of 8bit error location in 5th backup codeword     |
| 24:20      | RO          | 0x00               | err_loc4_I5<br>Lower 5 bits of number of 8bit error location in 4th backup codeword     |
| 19:15      | RO          | 0x00               | err_loc3_I5<br>Lower 5 bits of number of 8bit error location in 3rd backup codeword     |
| 14:10      | RO          | 0x00               | err_loc2_I5<br>Lower 5 bits of number of 8bit error location in 2nd backup codeword     |
| 9:5        | RO          | 0x00               | err_loc1_I5<br>Lower 5 bits of number of 8bit error location in 1st backup codeword     |
| 4:0        | RO          | 0x00               | err_loc0_I5<br>Lower 5 bits of number of 8bit error location in current backup codeword |

**NANDC\_BCHLOC1**

Address: Operational Base + offset (0x0044)

BCH error bit location number register for codeword 6~11

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                                                              |
| 29:25      | RO          | 0x00               | err_loc11_I5<br>Lower 5 bits of number of 8bit error location in 11th backup codeword |
| 24:20      | RO          | 0x00               | err_loc10_I5<br>Lower 5 bits of number of 8bit error location in 10th backup codeword |
| 19:15      | RO          | 0x00               | err_loc9_I5<br>Lower 5 bits of number of 8bit error location in 9th backup codeword   |
| 14:10      | RO          | 0x00               | err_loc8_I5<br>Lower 5 bits of number of 8bit error location in 8th backup codeword   |
| 9:5        | RO          | 0x00               | err_loc7_I5<br>Lower 5 bits of number of 8bit error location in 7th backup codeword   |
| 4:0        | RO          | 0x00               | err_loc6_I5<br>Lower 5 bits of number of 8bit error location in 6th backup codeword   |

**NANDC\_BCHLOC2**

Address: Operational Base + offset (0x0048)

BCH error bit location number register for codeword 12~15

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------|
| 31:20      | RO          | 0x0                | reserved                                                                              |
| 19:15      | RO          | 0x00               | err_loc15_l5<br>Lower 5 bits of number of 8bit error location in 15th backup codeword |
| 14:10      | RO          | 0x00               | err_loc14_l5<br>Lower 5 bits of number of 8bit error location in 4th backup codeword  |
| 9:5        | RO          | 0x00               | err_loc13_l5<br>Lower 5 bits of number of 8bit error location in 13th backup codeword |
| 4:0        | RO          | 0x00               | err_loc12_l5<br>Lower 5 bits of number of 8bit error location in 12th backup codeword |

**NANDC\_BCHLOC3**

Address: Operational Base + offset (0x004c)

Highest bit for BCH error bit location number register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                           |
|------------|-------------|--------------------|------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0                | reserved                                                                     |
| 15         | RO          | 0x0                | err_loc15_h1<br>High bit for numbers of 8bit error location in 15th codeword |
| 14         | RO          | 0x0                | err_loc14_h1<br>High bit for numbers of 8bit error location in 14th codeword |
| 13         | RO          | 0x0                | err_loc13_h1<br>High bit for numbers of 8bit error location in 13th codeword |
| 12         | RO          | 0x0                | err_loc12_h1<br>High bit for numbers of 8bit error location in 12th codeword |
| 11         | RO          | 0x0                | err_loc11_h1<br>High bit for numbers of 8bit error location in 11th codeword |
| 10         | RO          | 0x0                | err_loc10_h1<br>High bit for numbers of 8bit error location in 10th codeword |
| 9          | RO          | 0x0                | err_loc9_h1<br>High bit for numbers of 8bit error location in 9th codeword   |
| 8          | RO          | 0x0                | err_loc8_h1<br>High bit for numbers of 8bit error location in 8th codeword   |
| 7          | RO          | 0x0                | err_loc7_h1<br>High bit for numbers of 8bit error location in 7th codeword   |
| 6          | RO          | 0x0                | err_loc6_h1<br>High bit for numbers of 8bit error location in 6th codeword   |
| 5          | RO          | 0x0                | err_loc5_h1<br>High bit for numbers of 8bit error location in 5th codeword   |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------|
| 4          | RO          | 0x0                | err_loc4_h1<br>High bit for numbers of 8bit error location in 4th codeword |
| 3          | RO          | 0x0                | err_loc3_h1<br>High bit for numbers of 8bit error location in 3th codeword |
| 2          | RO          | 0x0                | err_loc2_h1<br>High bit for numbers of 8bit error location in 2th codeword |
| 1          | RO          | 0x0                | err_loc1_h1<br>High bit for numbers of 8bit error location in 1th codeword |
| 0          | RO          | 0x0                | err_loc0_h1<br>High bit for numbers of 8bit error location in 0th codeword |

**NANDC\_BCHDE0\_0**

Address: Operational Base + offset (0x0070)

BCH decode result of 0th error bit for codeword 0

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:19      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 18:8       | RO          | 0x000              | offset<br>The offset byte address of the error bit.<br>The value is 11bit, which is the byte offset address in the codeword.<br>The address can be divided into different part for different use,<br>showed as follows.<br>0 ~1023: page data<br>1024~1027: system information<br>1028~1055: bch information for 16bitBCH<br>1028~1069: bch information for 24bitBCH<br>1028~1097: bch information for 40bitBCH<br>1028~1132: bch information for 60bitBCH |
| 7:0        | RO          | 0x00               | err_val<br>The error value of corresponding error byte                                                                                                                                                                                                                                                                                                                                                                                                     |

**NANDC\_BCHDE0\_1**

Address: Operational Base + offset (0x0074)

BCH decode result of 1th error bit for codeword 0

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:19      | RO          | 0x0                | reserved                                                                                                                                                                  |
| 18:0       | RO          | 0x00000            | bchde0_1<br>Decode result of 1th error bit for codeword 0.<br>Bit assignment is similar to BCHDE0_0 register.<br>For more description, please refer to BCHDE0_0 register. |

**NANDC\_BCHDE0\_2**

Address: Operational Base + offset (0x0078)

BCH decode result of 2th error bit for codeword 0

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 18:0       | RO          | 0x00000            | bchde0_2<br>Decode result of 2th error bit for codeword 0.<br>Bit assignment is similar to BCHDE0_0 register.<br>For more description, please refer to BCHDE0_0 register. |

**NANDC\_BCHDE0\_3**

Address: Operational Base + offset (0x007c)  
BCH decode result of 3th error bit for codeword 0

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:19      | RO          | 0x0                | reserved                                                                                                                                                                  |
| 18:0       | RO          | 0x00000            | bchde0_3<br>Decode result of 3th error bit for codeword 0.<br>Bit assignment is similar to BCHDE0_0 register.<br>For more description, please refer to BCHDE0_0 register. |

**NANDC\_BCHDE0\_4**

Address: Operational Base + offset (0x0080)  
BCH decode result of 4th error bit for codeword 0

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:19      | RO          | 0x0                | reserved                                                                                                                                                                  |
| 18:0       | RO          | 0x00000            | bchde0_4<br>Decode result of 4th error bit for codeword 0.<br>Bit assignment is similar to BCHDE0_0 register.<br>For more description, please refer to BCHDE0_0 register. |

**NANDC\_BCHDE0\_5**

Address: Operational Base + offset (0x0084)  
BCH decode result of 5th error bit for codeword 0

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:19      | RO          | 0x0                | reserved                                                                                                                                                                  |
| 18:0       | RO          | 0x00000            | bchde0_5<br>Decode result of 5th error bit for codeword 0.<br>Bit assignment is similar to BCHDE0_0 register.<br>For more description, please refer to BCHDE0_0 register. |

**NANDC\_BCHDE0\_6**

Address: Operational Base + offset (0x0088)  
BCH decode result of 6th error bit for codeword 0

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:19      | RO          | 0x0                | reserved                                                                                                                                                                  |
| 18:0       | RO          | 0x00000            | bchde0_6<br>Decode result of 6th error bit for codeword 0.<br>Bit assignment is similar to BCHDE0_0 register.<br>For more description, please refer to BCHDE0_0 register. |

**NANDC\_BCHDE0\_7**

Address: Operational Base + offset (0x008c)

BCH decode result of 7th error bit for codeword 0

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:19      | RO          | 0x0                | reserved                                                                                                                                                                  |
| 18:0       | RO          | 0x00000            | bchde0_7<br>Decode result of 7th error bit for codeword 0.<br>Bit assignment is similar to BCHDE0_0 register.<br>For more description, please refer to BCHDE0_0 register. |

**NANDC\_BCHDE0\_8**

Address: Operational Base + offset (0x0090)

BCH decode result of 8th error bit for codeword 0

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:19      | RO          | 0x0                | reserved                                                                                                                                                                  |
| 18:0       | RO          | 0x00000            | bchde0_8<br>Decode result of 8th error bit for codeword 0.<br>Bit assignment is similar to BCHDE0_0 register.<br>For more description, please refer to BCHDE0_0 register. |

**NANDC\_BCHDE0\_9**

Address: Operational Base + offset (0x0094)

BCH decode result of 9th error bit for codeword 0

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:19      | RO          | 0x0                | reserved                                                                                                                                                                  |
| 18:0       | RO          | 0x00000            | bchde0_9<br>Decode result of 9th error bit for codeword 0.<br>Bit assignment is similar to BCHDE0_0 register.<br>For more description, please refer to BCHDE0_0 register. |

**NANDC\_BCHDE0\_10**

Address: Operational Base + offset (0x0098)

BCH decode result of 10th error bit for codeword 0

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:19      | RO          | 0x0                | reserved                                                                                                                                                                    |
| 18:0       | RO          | 0x00000            | bchde0_10<br>Decode result of 10th error bit for codeword 0.<br>Bit assignment is similar to BCHDE0_0 register.<br>For more description, please refer to BCHDE0_0 register. |

**NANDC\_BCHDE0\_11**

Address: Operational Base + offset (0x009c)

BCH decode result of 11th error bit for codeword 0

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

| Bit  | Attr | Reset Value | Description                                                                                                                                                                 |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 18:0 | RO   | 0x00000     | bchde0_11<br>Decode result of 11th error bit for codeword 0.<br>Bit assignment is similar to BCHDE0_0 register.<br>For more description, please refer to BCHDE0_0 register. |

**NANDC\_BCHDE0\_12**

Address: Operational Base + offset (0x00a0)

BCH decode result of 12th error bit for codeword 0

| Bit   | Attr | Reset Value | Description                                                                                                                                                                 |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:19 | RO   | 0x0         | reserved                                                                                                                                                                    |
| 18:0  | RO   | 0x00000     | bchde0_12<br>Decode result of 12th error bit for codeword 0.<br>Bit assignment is similar to BCHDE0_0 register.<br>For more description, please refer to BCHDE0_0 register. |

**NANDC\_BCHDE0\_13**

Address: Operational Base + offset (0x00a4)

BCH decode result of 13th error bit for codeword 0

| Bit   | Attr | Reset Value | Description                                                                                                                                                                 |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:19 | RO   | 0x0         | reserved                                                                                                                                                                    |
| 18:0  | RO   | 0x00000     | bchde0_13<br>Decode result of 13th error bit for codeword 0.<br>Bit assignment is similar to BCHDE0_0 register.<br>For more description, please refer to BCHDE0_0 register. |

**NANDC\_BCHDE0\_14**

Address: Operational Base + offset (0x00a8)

BCH decode result of 14th error bit for codeword 0

| Bit   | Attr | Reset Value | Description                                                                                                                                                                 |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:19 | RO   | 0x0         | reserved                                                                                                                                                                    |
| 18:0  | RO   | 0x00000     | bchde0_14<br>Decode result of 14th error bit for codeword 0.<br>Bit assignment is similar to BCHDE0_0 register.<br>For more description, please refer to BCHDE0_0 register. |

**7.5 Interface Description**

Table 7-2 NandC Interface Description

| Module Pin    | Direction | Pad Name      | IOMUX Setting               |
|---------------|-----------|---------------|-----------------------------|
| flash_ale     | O         | FLASH_ALE     | GRF_GPIO2A_IOMUX[1:0]=2'b01 |
| flash_cle     | O         | FLASH_CLE     | GRF_GPIO2A_IOMUX[3:2]=2'b01 |
| flash_wrn     | O         | FLASH_WRN     | GRF_GPIO2A_IOMUX[5:4]=2'b01 |
| flash_rdn     | O         | FLASH_RDN     | GRF_GPIO2A_IOMUX[7:6]=2'b01 |
| flash_data[0] | I/O       | FLASH_DATA[0] | GRF_GPIO1D_IOMUX[1:0]=2'b01 |
| flash_data[1] | I/O       | FLASH_DATA[1] | GRF_GPIO1D_IOMUX[3:2]=2'b01 |
| flash_data[2] | I/O       | FLASH_DATA[2] | GRF_GPIO1D_IOMUX[5:4]=2'b01 |
| flash_data[3] | I/O       | FLASH_DATA[3] | GRF_GPIO1D_IOMUX[7:6]=2'b01 |

| <b>Module Pin</b> | <b>Direction</b> | <b>Pad Name</b> | <b>IOMUX Setting</b>          |
|-------------------|------------------|-----------------|-------------------------------|
| flash_data[4]     | I/O              | FLASH_DATA[4]   | GRF_GPIO1D_IOMUX[9:8]=2'b01   |
| flash_data[5]     | I/O              | FLASH_DATA[5]   | GRF_GPIO1D_IOMUX[11:10]=2'b01 |
| flash_data[6]     | I/O              | FLASH_DATA[6]   | GRF_GPIO1D_IOMUX[13:12]=2'b01 |
| flash_data[7]     | I/O              | FLASH_DATA[7]   | GRF_GPIO1D_IOMUX[15:14]=2'b01 |
| flash_rdy         | I                | FLASH_RDY       | GRF_GPIO2A_IOMUX[9:8]=2'b01   |
| flash_csn0        | O                | FLASH0_CSN      | GRF_GPIO2A_IOMUX[12]=1'b1     |

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

Furthermore, different IOs are selected and connected to flash interface, which is shown as follows.

Table 7-3 NandC Interface Connection

| <b>Module Pin</b> | <b>Direction</b> | <b>Flash Interface</b> |                |             |               |
|-------------------|------------------|------------------------|----------------|-------------|---------------|
|                   |                  | <b>Asyn8x</b>          | <b>Asyn16x</b> | <b>ONFI</b> | <b>Toggle</b> |
| flash_csn0        | O                | ✓                      | -              | -           | -             |
| flash_ale         | O                | ✓                      | -              | -           | -             |
| flash_cle         | O                | ✓                      | -              | -           | -             |
| flash_wrn         | O                | ✓                      | -              | -           | -             |
| flash_rdn         | O                | ✓                      | -              | -           | -             |
| flash_data[7:0]   | I/O              | ✓                      | -              | -           | -             |
| flash_rdy         | I                | ✓                      | -              | -           | -             |

## 7.6 Application Notes

### 7.6.1 BCHST/BCHLOC/BCHDE/SPARE Application

#### 1. BCHST

There are 8 BCHST-registers in NandC to store 16 codeword's BCH decode status(bchst) information. Every register stores 2 codeword's bchst information except BCHST0, which not only includes bchst information, but also includes one bit for *bchrny*.

Let bchst\_cwd0~bchst\_cwd15 be the bchst information for 16 codewords. In BCHST-registers, the latest codeword's bchst is stored into bchst\_cwd0, and the former is shifted into bchst\_cwd1. That is, bchst\_cwd0 → bchst\_cwd1 → ..... → bchst\_cwd15. Therefore, for example, if 16 codewords are decoded, then bchst\_cwd0 is the bch decode status for codeword15, and bchst\_cwd15 is the bch decode status for codeword0.

bchst\_cwd0 = {BCHST0[28], BCHST0[12:8], BCHST0[27], BCHST0[7:3], BCHST0[2:0]}

bchst\_cwd1 = {BCHST0[30], BCHST0[25:21], BCHST0[29], BCHST0[20:16],  
BCHST0[15:13]}

bchst\_cwd2 = {BCHST1[28], BCHST1[12:8], BCHST1[27], BCHST1[7:3], BCHST1[2:0]}

bchst\_cwd3 = {BCHST1[30], BCHST1[25:21], BCHST1[29], BCHST1[20:16],  
BCHST1[15:13]}

bchst\_cwd4 = {BCHST2[28], BCHST2[12:8], BCHST2[27], BCHST2[7:3], BCHST2[2:0]}

bchst\_cwd5 = {BCHST2[30], BCHST2[25:21], BCHST2[29], BCHST2[20:16],  
BCHST2[15:13]}

bchst\_cwd6 = {BCHST3[28], BCHST3[12:8], BCHST3[27], BCHST3[7:3], BCHST3[2:0]}

bchst\_cwd7 = {BCHST3[30], BCHST3[25:21], BCHST3[29], BCHST3[20:16],  
BCHST3[15:13]}

bchst\_cwd8 = {BCHST4[28], BCHST4[12:8], BCHST4[27], BCHST4[7:3], BCHST4[2:0]}

bchst\_cwd9 = {BCHST4[30], BCHST4[25:21], BCHST4[29], BCHST4[20:16],  
BCHST4[15:13]}

bchst\_cwd10 = {BCHST5[28], BCHST5[12:8], BCHST5[27], BCHST5[7:3], BCHST5[2:0]}

bchst\_cwd11 = {BCHST5[30], BCHST5[25:21], BCHST5[29], BCHST5[20:16],  
BCHST5[15:13]}

bchst\_cwd12 = {BCHST6[28], BCHST6[12:8], BCHST6[27], BCHST6[7:3], BCHST6[2:0]}

bchst\_cwd13 = {BCHST6[30], BCHST6[25:21], BCHST6[29], BCHST6[20:16],  
BCHST6[15:13]}

bchst\_cwd14 = {BCHST7[28], BCHST7[12:8], BCHST7[27], BCHST7[7:3], BCHST7[2:0]}

bchst\_cwd15 = {BCHST7[30], BCHST7[25:21], BCHST7[29], BCHST7[20:16],  
BCHST7[15:13]}

## 2. BCHLOC

There are 4 BCHLOC-registers in NandC to store 16 codeword's bch decode location(bchloc) information.

Let bchloc\_cwd0~bchloc\_cwd15 be the bchloc information for the 16 codeword. In BCHLOC registers, the latest codeword's bchloc is stored into bchloc\_cwd0, and the former is shifted into bchloc\_cwd1. That is, bchloc\_cwd0→bchloc\_cwd1→.....→bchloc\_cwd15. Therefore, for example, if 16 codeword are decoded, then bchloc\_cwd0 is the bch decode status for codeword15, and bchloc\_cwd15 is the bch decode status for codeword0.

```
bchloc_cwd0 = {BCHLOC3[0], BCHLOC0[4:0]}
bchloc_cwd1 = {BCHLOC3[1], BCHLOC0[9:5]}
bchloc_cwd2 = {BCHLOC3[2], BCHLOC0[14:10]}
bchloc_cwd3 = {BCHLOC3[3], BCHLOC0[19:15]}
bchloc_cwd4 = {BCHLOC3[4], BCHLOC0[24:20]}
bchloc_cwd5 = {BCHLOC3[5], BCHLOC0[29:25]}
bchloc_cwd6 = {BCHLOC3[6], BCHLOC1[4:0]}
bchloc_cwd7 = {BCHLOC3[7], BCHLOC1[9:5]}
bchloc_cwd8 = {BCHLOC3[8], BCHLOC1[14:10]}
bchloc_cwd9 = {BCHLOC3[9], BCHLOC1[19:15]}
bchloc_cwd10 = {BCHLOC3[10], BCHLOC1[24:20]}
bchloc_cwd11 = {BCHLOC3[11], BCHLOC1[29:25]}
bchloc_cwd12 = {BCHLOC3[12], BCHLOC2[4:0]}
bchloc_cwd13 = {BCHLOC3[13], BCHLOC2[9:5]}
bchloc_cwd14 = {BCHLOC3[14], BCHLOC2[14:10]}
bchloc_cwd15 = {BCHLOC3[15], BCHLOC2[19:15]}
```

## 3. BCHDE

BCHDE includes two register-groups, BCHDE0 and BCHDE1. Each group has 60 registers: BCHDE0\_0~BCHDE0\_59 and BCHDE1\_0~BCHDE1\_59. BCHDE0\_n(n=0~59) is the decode information of the nth error bit for codeword in sram0, and BCHDE1\_n(n=0~59) is the decode information of the nth error bit for codeword in sram1.

The needed number of BCHDE registers is determined by bchmode. That is:

- a. When 16bitBCH selected, BCHDEm\_0 ~ BCHDEm\_15 are available
- b. When 24bitBCH selected, BCHDEm\_0 ~ BCHDEm\_23 are available
- c. When 40bitBCH selected, BCHDEm\_0 ~ BCHDEm\_39 are available
- d. When 60bitBCH selected, BCHDEm\_0 ~ BCHDEm\_59 are available

## 4. SPARE

SPARE includes two register-groups, SPARE0 and SPARE1. Each group has 28 registers:

SPARE0\_0~SPARE0\_27 and SPARE1\_0~SPARE1\_27.

When in bch encoding, SPARE0\_0 stores system information for codeword in sram0, SPARE0\_n(n=1~27) stores encode information for codeword in sram0; SPARE1\_0 stores system information for codeword in sram1, SPARE1\_n( n=1~27) stores encode information for codeword in sram1.

When in bch decoding, SPARE0\_n(n=0~27) stores the spare data read from flash for codeword in sram0; SPARE1\_n(n=0~27) stores the spare data read from flash for codeword in sram1.

The needed number of BCHDE registers is determined by bchmode. That is:

- a. When 16bitBCH selected, spare data=28bytes, SPAREm\_0~SPAREm\_7 are available
- b. When 24bitBCH selected, spare data=42bytes, SPAREm\_0~SPAREm\_10 and SPAREm\_11[15:0] are available
- c. When 40bitBCH selected, spare data=70bytes, SPAREm\_0~SPAREm\_17 and SPAREm\_18[15:0] are available
- d. When 60bitBCH selected, spare data=105bytes, SPAREm\_0~SPAREm\_26 and SPAREm\_27[7:0] are available

## 7.6.2 Bus Mode Application

MTRANS\_CFG[2] determines whether the data load/store between internal memory and external memory is through slave interface or master interface.

### 1. Slave Mode

When MTRANS\_CFG[2]=0, slave is selected. i.e., flash data load/store between internal

memory and external memory is through slave interface by CPU or external DMA. In this mode, software should store page data into internal memory and spare data into SPARE registers before starting flash program operation; and should load page data from internal memory and spare data from SPARE registers after finishing flash read operation. In this mode, MTRANS\_CFG, MTRANS\_SADDR0 and MTRANS\_SADDR1 are unused. The transfer codeword number is determined by FLCTL[6:5], and the maximum number is 2. The judgment condition for finishing data transfer is FLCTL[20]. When FLCTL[20] is high, it means that data transfer is finished.

## 2. Master Mode

When MTRANS\_CFG[2]=1, master is selected. i.e., flash data load/store between internal memory and external memory is through master interface.

In this mode, software should initialize page data and spare data into external memory, and set their addresses in MTRANS\_SADDR0 and MTRANS\_SADDR1 respectively before starting flash program operation. Similarly, software should configure MTRANS\_SADDR0 and MTRANS\_SADDR1 respectively before starting flash read operation and could read data from addresses in MTRANS\_SADDR0 and MTRANS\_SADDR1 after NandC transfer finish.

In this mode, MTRANS\_CFG, MTRANS\_SADDR0 and MTRANS\_SADDR1 are used. The transfer codeword number is determined by FLCTL[26:22], and the maximum number is 16.

The judgment condition for finishing data transfer is FLCTL[20]. When FLCTL[20] is high, it means that data transmission is finished.

When MTRANS\_CFG[2]=1, page data and spare data are stored in the continuous space of external memory respectively.

For page data, source address is named Saddr0, specified in MTRANS\_SADDR0. The space can be divided into many continuous units, and the unit size(named PUnit) is 1024 bytes or 512 bytes determined by FLCTL[21] and FLCTL[11]:

- a.when FLCTL[11]=0, PUnit is always equal to 1024 bytes
- b.when FLCTL[11]=1 and FLCTL[21]=0, PUnit is equal to 1024 bytes
- c.when FLCTL[11]=1 and FLCTL[21]=1, PUnit is equal to 512 bytes

For spare data, source address is named Saddr1, specified in MTRANS\_SADDR1. The space can be divided into many continuous units, and the unit size(named SUnit) is 64 bytes or 128 bytes determined by BCHCTL[18], FLCTL[11] and FLCTL[21]:

- a.When FLCTL[11]=0 and BCHCTL[18]=0, SUnit is equal to 64 bytes
- b.When FLCTL[11]=0 and BCHCTL[18]=1, SUnit is equal to 128 bytes
- c.When FLCTL[11]=1 and FLCTL[21]=0, SUnit is equal to 128 bytes
- d.When FLCTL[11]=1 and FLCTL[21]=1, SUnit is equal to 64 bytes



Fig. 7-2 NandC Address Assignment

The detailed format for page data and spare data in every unit is shown in following figures.



Fig. 7-3 NandC Data Format

### 7.6.3 BchPage Application

BCHCTL[16] determines whether codeword size for page data is 1024 bytes or 512 bytes when FLCTL[11] is 0.

#### 1. 1024bytes

When BCHCTL[16]=0, BchPage=0, hardware needs to write 1024 bytes page data and spare data into flash or read 1024 bytes page data and spare data from flash. All the 1024 bytes page data and spare data are encoded when writing or decoded when reading.

#### 2. 512bytes

When BCHCTL[16]=1, BchPage=1, hardware needs to write 512 bytes page data and spare data into flash or read 512 bytes page data and spare data from flash.

In this mode, the page data unit size for BCH encoder and BCH decoder still is 1024byte. So to support BCH encoder and decoder, software should configure page data as follows: 1th~512th bytes are invalid data which must be stuffed with 0xff, 513th~1024th bytes are valid page data.

However, Randomizer function is not supported under this condition.

### 7.6.4 PageSize/SpareSize Application

FLCTL[21] determines whether the codeword size is 1024 bytes or 512 bytes when FLCTL[11] is 1.

#### 1. Big Page

When FLCTL[11]=0(LbaEn=0), the flash to be operated is Raw NAND Flash. Every codeword size is 1024 bytes and FLCTL[21] should always be set to 0, and the PageStep in external memory is 1024 bytes if bus mode is master mode.

At this mode, the spare size and SpareStep in external memory are determined by BCH Mode as follows:

BCH Mode=16bitBCH: spare size=(28+4)bytes , SpareStep=64bytes

BCH Mode=24bitBCH: spare size=(42+4)bytes , SpareStep=64bytes

BCH Mode=40bitBCH: spare size=(70+4)bytes , SpareStep=128bytes

BCH Mode=60bitBCH: spare size=(105+4)bytes, SpareStep=128bytes

#### 2. Small Page

When FLCTL[11]=1, LbaEn=1, the flash to be operated is Managed NAND Flash. Every codeword size could be 1024 bytes or 512 bytes according to FLCTL[21]. If FLCTL[21]=0, codeword size is 1024 bytes, PageStep in external memory is 1024 bytes, and SpareStep is 128bytes. If FLCTL[21]=1, codeword size is 512 bytes, PageStep in external memory is 512 bytes, and SpareStep is 64 bytes.

At this mode, the spare size is configured in FLCTL[18:12], and the max available number is 109.

In the summary, the total data size in every codeword for flash or for software including page data and spare data, is determined by BCHCTL[16], FLCTL[11], FLCTL[21], BCHCTL[4], BCHCTL[18]. Their relationship is shown as follows.

Table 7-4 NandC Page/Spare size for flash

| page/spare size for software | page size /codeword | spare size /codeword      |
|------------------------------|---------------------|---------------------------|
| FLCTL[11]=0                  | 16bitECC            | 1024 byte<br>(4+28)byte   |
|                              | 24bitECC            | 1024 byte<br>(4+42)byte   |
|                              | 40bitECC            | 1024 byte<br>(4+70)byte   |
|                              | 60bitECC            | 1024 byte<br>(4+105)byte  |
| FLCTL[11]=1                  | FLCTL[21]=0         | 1024 byte<br>FLCTL[18:12] |
|                              | FLCTL[21]=1         | 512 byte<br>FLCTL[18:12]  |

Notes: that "page/spare size for flash" means that hardware should transfer these numbers of bytes in every codeword to or from flash.

## 7.6.5 Randomizer Application

RANDMZ\_CFG[31] determines whether randomizer is enable or not. When RANDMZ\_CFG[31] equals to 1, randomizer is active. Data should be scrambled before written into flash, and descrambled after read from flash.

RANDMZ\_CFG[30] determines the randomizer polynomial.

When RANDMZ\_CFG[30]=0, Polynomial= $1+x^{18}+x^{23}$

When RANDMZ\_CFG[30]=1, Polynomial= $1+x^{14}+x^{15}$

RANDMZ\_CFG[22:0] is the seed for randomizer. It should be ensured that data in the same page should have the same randomizer polynomial and randomizer seed when in flash program or flash read operation.

The data unit for randomizer is one codeword(data+spare).

However, Randomizer is just available for data transfer by internal DMA mode, but not by for bypass mode. Furthermore, it should not be enable if BCHCTL[16]=0 (BchPage=512bytes).

## 7.6.6 NandC Interrupt Application

NandC has 1 interrupt output signal and 4 interrupt sources: DMA finish interrupt source, flash ready interrupt source, bch error interrupt source, BCH fail interrupt source. When one or more of these interrupt source are enabled, NandC interrupt is asserted if one or more interrupt source is high. Software can determine the interrupt source by reading INTST and clear interrupt by writing corresponding bit in INTCLR.

## 7.6.7 LLP Application

LLP is used in NandC to store and execute instruction groups configured in external memory by software. When LLPCTL[0]=1, LLP is active, NandC will load instruction groups stored in {LLPCTL[31:6], 6'h0} and execute them. Next instruction groups should not be loaded until current instruction execution finished.

### 1. LLP Structure

The structure of LLP is shown as follows:



Fig. 7-4 NandC LLP Data Format

LLI\_MODE is determined by LLPCTL[1]. If current operation is flash program or flash read, then LLI\_MODE=1 is need; otherwise, LLI\_MODE=0 is workable.  
In addition, you could do more than one flash operation in one LLP group, but you should not separate one flash operation into two LLI groups.

## 2. LLI Format

- a. LLI\_LLPO<sub>n+1</sub> stores the address for next LLI group data



### b. LLI\_FOP0~LLI\_FOP14 store the flash operation instruction



When FOP\_TYPE=3'b011, match operation is active, and the PATTERN is LLI\_FOP[15:0]. It is matched when "RDATA|PATTERN=PATTERN" with FOP\_MATCHMOD=0, or when "RDATA&PATTERN=PATTERN" with FOP\_MATCHMOD=1.

c.LLI\_MTRANS\_CFG/LLI\_MTRANS\_SADDR0/LLI\_MTRANS\_SADDR1/LLI\_RANDMZ/LLI\_FLCTL store the configuration for MTRANS\_CFG/MTRANS\_SADDR0/MTRANS\_SADDR1/RANDMZ/FLCTL.

### 3. LLP Working Mode

There are two working modes for LLP:

- Normal mode: LLPCTL[0] is kept to 1 until all LLP loading and executing finished. Software can monitor the progress by LLPSTAT[31:6], LLPSTAT[0].
- Pause mode: LLPCTL[0] is changed from 1 to 0 during LLP loading or LLP executing. NandC should not stop working until current LLP executing finished. Software can monitor the progress by LLPSTAT[31:6], LLPSTAT[0].

## Chapter 8 Timer

### 8.1 Overview

Timer is a programmable timer peripheral. This component is an APB slave device. Timer0~2 count down from a programmed value and generate an interrupt when the count reaches zero.

Timer5 counts up from zero to a programmed value and generate an interrupt when the count reaches the programmed value.

Timer supports the following features:

- One APB timer in the PERI subsystem, include four programmable 64 bits timer channels, acts as TIMER0, TIMER1, TIMER2, and TIMER5 respectively
- Two operation modes: free-running and user-defined count
- Maskable for each individual interrupt
- TIMER5 is used for CPU; others are used for normalization.

### 8.2 Block Diagram



Fig. 8-1 Timer Block Diagram

The above figure shows the architecture of the APB timer (include four programmable timer channel).

### 8.3 Function Description

#### 8.3.1 Timer clock

The timer clock can be selected from 24MHz OSC or pclk in PERI bus respectively for TIMER0/1/2/5 by CRU\_CLKSEL2\_CON[0]/[1]/[2]/[3].

#### 8.3.2 Programming sequence

1. Initialize the timer by the TIMERn\_CONTROLREG ( $n=0,1,2,5$ ) register:
  - Disable the timer by writing a "0" to the timer enable bit (bit 0). Accordingly, the timer\_en output signal is de-asserted.
  - Program the timer mode—user-defined or free-running—by writing a "0" or "1" respectively, to the timer mode bit (bit 1).
  - Set the interrupt mask as either masked or not masked by writing a "0" or "1" respectively, to the timer interrupt mask bit (bit 2).
2. Load the timer count value into the TIMERn\_LOAD\_COUNT1 ( $n=0,1,2,5$ ) and TIMERn\_LOAD\_COUNT0 ( $n=0,1,2,5$ ) register.
3. Enable the timer by writing a "1" to bit 0 of TIMERn\_CONTROLREG ( $n=0,1,2,5$ ).



Fig. 8-2 Timer Usage Flow

### 8.3.3 Loading a timer count value

The initial value for each timer — that is, the value from which it counts down — is loaded into the timer using the load count register (TIMERn\_LOAD\_COUNT1 (n=0,1,2,5) and TIMERn\_LOAD\_COUNT0 (n=0,1,2,5)). Two events can cause a timer to load the initial value from its load count register:

- Timer is enabled after reset or disabled.
- Timer counts down to 0, when timer is configured into free-running mode.

### 8.3.4 Timer mode selection

- User-defined count mode – Timer loads TIMERn\_LOAD\_COUNT1 (n=0,1,2,5) and TIMERn\_LOAD\_COUNT0 (n=0,1,2,5) register as initial value. Timer will not automatically load the counter register, when timer counts down to 0. User need to disable timer firstly and follow the programming sequence to make timer work again.
- Free-running mode – Timer loads the TIMERn\_LOAD\_COUNT1 (n=0,1,2,5) and TIMERn\_LOAD\_COUNT0 (n=0,1,2,5) register as initial value. Timer will automatically load the counter register, when timer counts down to 0.

## 8.4 Register Description

This section describes the control/status registers of the design. Software should read and write these registers using 32-bits accesses.

### 8.4.1 Registers Summary

| Name                     | Offset | Size | Reset Value | Description                     |
|--------------------------|--------|------|-------------|---------------------------------|
| RKTIMER_n_LOAD_COUNTL    | 0x0000 | W    | 0x00000001f | Timer n Load Count Register     |
| RKTIMER_n_LOAD_COUNTH    | 0x0004 | W    | 0x000000000 | Timer n Load Count Register     |
| RKTIMER_n_CURRENT_VALUEL | 0x0008 | W    | 0x000000000 | Timer n Current Value Register  |
| RKTIMER_n_CURRENT_VALUEH | 0x000c | W    | 0x000000000 | Timer n Current Value Register  |
| RKTIMER_n_CONTROLREG     | 0x0010 | W    | 0x000000000 | Timer n Control Register        |
| RKTIMER_n_INTSTATUS      | 0x0014 | W    | 0x000000000 | Timer Interrupt Stauts Register |

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

### 8.4.2 Detail Register Description

#### RKTIMER\_n\_LOAD\_COUNTL

Address: Operational Base + offset (0x0000)

Timer n Load Count Register

| Bit  | Attr | Reset Value | Description                                                                                                         |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000001f | load_count_lowbits<br>Low 32 bits value to be loaded into Timer n. This is the value from which counting commences. |

#### RKTIMER\_n\_LOAD\_COUNTH

Address: Operational Base + offset (0x0004)

Timer n Load Count Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | load_count_highbits<br>High 32 bits value to be loaded into Timer n. This is the value from which counting commences. |

**RKTIMER\_n\_CURRENT\_VALUEL**

Address: Operational Base + offset (0x0008)

Timer n Current Value Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | current_cnt_lowbits<br>Low 32 bits of current value of timer n. |

**RKTIMER\_n\_CURRENT\_VALUEH**

Address: Operational Base + offset (0x000c)

Timer n Current Value Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | current_cnt_highbits<br>High 32 bits of current value of timer n. |

**RKTIMER\_n\_CONTROLREG**

Address: Operational Base + offset (0x0010)

Timer n Control Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------|
| 31:3       | RO          | 0x0                | reserved                                                                        |
| 2          | RW          | 0x0                | int_en<br>Timer interrupt mask<br>0: mask<br>1: not mask                        |
| 1          | RW          | 0x0                | timer_mode<br>Timer mode.<br>0: free-running mode<br>1: user-defined count mode |
| 0          | RW          | 0x0                | timer_en<br>Timer enable.<br>0: disable<br>1: enable                            |

**RKTIMER\_n\_INTSTATUS**

Address: Operational Base + offset (0x0014)

Timer Interrupt Stants Register

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

| Bit | Attr | Reset Value | Description                                                                                                              |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------|
| 0   | W1C  | 0x0         | int_pd<br>This register contains the interrupt status for timer n.<br>Write 1 to this register will clear the interrupt. |

## 8.5 Application Notes

In the chip, the timer\_clk is from 24MHz OSC, asynchronous to the pclk. When user disables the timer enables bit (bit 0 of TIMERn\_CONTROLREG (n=0,1,2,5)), the timer\_en output signal is de-asserted, and timer\_clk will stop. When user enables the timer, the timer\_en signal is asserted and timer\_clk will start running.

The application is only allowed to re-config registers when timer\_en is low.



Fig. 8-3 Timing between timer\_en and timer\_clk

Please refer to function description section for the timer usage flow.

## Chapter 9 Generic Interrupt Controller (GIC)

### 9.1 Overview

The generic interrupt controller (GIC400) in this device has two interfaces, the distributor interface connects to the interrupt source, and the CPU interface connects to Cortex-A7.

It supports the following features:

- Supports 128 hardware interrupt inputs
- Masking of any interrupts
- Prioritization of interrupts
- Distribution of the interrupts to the target Cortex-A7 processor(s)
- Generation of interrupts by software
- Supports Security Extensions

### 9.2 Block Diagram

The generic interrupt controller comprises with:



Fig. 9-1 GIC Block Diagram

## Chapter 10 DMA Controller(DMAC)

### 10.1 Overview

DMAC is mainly used for data transfer of the following slaves: I2S, UART0, UART1, UART2, SPI, SDMMC, SDIO, EMMC, SPDIF.

Following table shows the DMAC request mapping scheme.

Table 10-1 DMAC Request Mapping Table

| Req number | Source   | Polarity   |
|------------|----------|------------|
| 0          | I2S tx   | High level |
| 1          | I2S rx   | High level |
| 2          | Uart0 tx | High level |
| 3          | Uart0 rx | High level |
| 4          | Uart1 tx | High level |
| 5          | Uart1 rx | High level |
| 6          | Uart2 tx | High level |
| 7          | Uart2 rx | High level |
| 8          | SPI tx   | High level |
| 9          | SPI rx   | High level |
| 10         | SDMMC    | High level |
| 11         | SDIO     | High level |
| 12         | EMMC     | High level |
| 13         | SPDIF tx | High level |

DMAC supports the following features:

- Supports 14 peripheral request.
- Up to 64bits data size
- 8 channel at the same time
- Up to burst 16
- 16 interrupts output and 1 abort output
- Supports 64 MFIFO depth.

### 10.2 Block Diagram

Following figure shows the block diagram of DMAC.



Fig. 10-1 Block diagram of DMAC

## 10.3 Function Description

### 10.3.1 Introduction

The DMAC contains an instruction processing block that enables it to process program code that controls a DMA transfer. The program code is stored in a region of system memory that the DMAC accesses using its AXI interface. The DMAC stores instructions temporarily in a cache.

DMAC supports 8 channels, each channel capable of supporting a single concurrent thread of DMA operation. In addition, a single DMA manager thread exists, and you can use it to initialize the DMA channel threads. The DMAC executes up to one instruction for each AXI clock cycle. To ensure that it regularly executes each active thread, it alternates by processing the DMA manager thread and then a DMA channel thread. It uses a round-robin process when selecting the next active DMA channel thread to execute.

The DMAC uses variable-length instructions that consist of one to six bytes. It provides a separate Program Counter (PC) register for each DMA channel. When a thread requests an instruction from an address, the cache performs a look-up. If a cache hit occurs, then the cache immediately provides the data. Otherwise, the thread is stalled while the DMAC uses the AXI interface to perform a cache line fill. If an instruction is greater than 4 bytes, or spans the end of a cache line, the DMAC performs multiple cache accesses to fetch the instruction. When a cache line fill is in progress, the DMAC enables other threads to access the cache, but if another cache miss occurs, this stalls the pipeline until the first line fill is complete.

When a DMA channel thread executes a load or store instruction, the DMAC adds the instruction to the relevant read or write queue. The DMAC uses these queues as an instruction storage buffer prior to it issuing the instructions on the AXI bus. The DMAC also contains a Multi First-In-First-Out (MFIFO) data buffer that it uses to store data that it reads, or writes, during a DMA transfer.

### 10.3.2 Operating states

Following figure shows the operating states for the DMA manager thread and DMA channel threads.



Fig. 10-2 DMAC operation states

*Notes: arcs with no letter designator indicate state transitions for the DMA manager and DMA channel threads, otherwise use is restricted as follows:*

C DMA channel threads only.

M DMA manager thread only.

After the DMAC exits from reset, it sets all DMA channel threads to the stopped state, and the status of boot\_from\_pc(tie-off interface of dmac) controls the DMA manager thread state: boot\_from\_pc is LOW :DMA manager thread moves to the Stopped state. boot\_from\_pc is HIGH :DMA manager thread moves to the Executing state.

## 10.4 Register Description

### 10.4.1 Registers Summary

| Name           | Offset | Size | Reset Value | Description                         |
|----------------|--------|------|-------------|-------------------------------------|
| DMAC_DSR       | 0x0000 | W    | 0x00000000  | DMA Manager Status Register         |
| DMAC_DPC       | 0x0004 | W    | 0x00000000  | DMA Program Counter Register        |
| DMAC_INTEN     | 0x0020 | W    | 0x00000000  | Interrupt Enable Register           |
| DMAC_EVENT_RIS | 0x0024 | W    | 0x00000000  | Event-Interrupt Raw Status Register |
| DMAC_INTMIS    | 0x0028 | W    | 0x00000000  | Interrupt Status Register           |
| DMAC_INTCLR    | 0x002c | W    | 0x00000000  | Interrupt Clear Register            |
| DMAC_FSRD      | 0x0030 | W    | 0x00000000  | Fault Status DMA Manager Register   |
| DMAC_FSRC      | 0x0034 | W    | 0x00000000  | Fault Status DMA Channel Register   |
| DMAC_FTRD      | 0x0038 | W    | 0x00000000  | Fault Type DMA Manager Register     |
| DMAC_FTR0      | 0x0040 | W    | 0x00000000  | Fault Type DMA Channel Register     |
| DMAC_FTR1      | 0x0044 | W    | 0x00000000  | Fault Type DMA Channel Register     |
| DMAC_FTR2      | 0x0048 | W    | 0x00000000  | Fault Type DMA Channel Register     |
| DMAC_FTR3      | 0x004c | W    | 0x00000000  | Fault Type DMA Channel Register     |
| DMAC_FTR4      | 0x0050 | W    | 0x00000000  | Fault Type DMA Channel Register     |
| DMAC_FTR5      | 0x0054 | W    | 0x00000000  | Fault Type DMA Channel Register     |
| DMAC_FTR6      | 0x0058 | W    | 0x00000000  | Fault Type DMA Channel Register     |
| DMAC_FTR7      | 0x005c | W    | 0x00000000  | Fault Type DMA Channel Register     |
| DMAC_CSR0      | 0x0100 | W    | 0x00000000  | Channel Status Registers            |
| DMAC_CPC0      | 0x0104 | W    | 0x00000000  | Channel Program Counter Registers   |
| DMAC_CSR1      | 0x0108 | W    | 0x00000000  | Channel Status Registers            |
| DMAC_CPC1      | 0x010c | W    | 0x00000000  | Channel Program Counter Registers   |
| DMAC_CSR2      | 0x0110 | W    | 0x00000000  | Channel Status Registers            |
| DMAC_CPC2      | 0x0114 | W    | 0x00000000  | Channel Program Counter Registers   |
| DMAC_CSR3      | 0x0118 | W    | 0x00000000  | Channel Status Registers            |
| DMAC_CPC3      | 0x011c | W    | 0x00000000  | Channel Program Counter Registers   |
| DMAC_CSR4      | 0x0120 | W    | 0x00000000  | Channel Status Registers            |
| DMAC_CPC4      | 0x0124 | W    | 0x00000000  | Channel Program Counter Registers   |
| DMAC_CSR5      | 0x0128 | W    | 0x00000000  | Channel Status Registers            |
| DMAC_CPC5      | 0x012c | W    | 0x00000000  | Channel Program Counter Registers   |
| DMAC_CSR6      | 0x0130 | W    | 0x00000000  | Channel Status Registers            |
| DMAC_CPC6      | 0x0134 | W    | 0x00000000  | Channel Program Counter Registers   |
| DMAC_CSR7      | 0x0138 | W    | 0x00000000  | Channel Status Registers            |

| <b>Name</b>    | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>                |
|----------------|---------------|-------------|--------------------|-----------------------------------|
| DMAC_CPC7      | 0x013c        | W           | 0x00000000         | Channel Program Counter Registers |
| DMAC_SAR0      | 0x0400        | W           | 0x00000000         | Source Address Registers          |
| DMAC_DAR0      | 0x0404        | W           | 0x00000000         | Destination Address Registers     |
| DMAC_CCR0      | 0x0408        | W           | 0x00000000         | Channel Control Registers         |
| DMAC_LC0_0     | 0x040c        | W           | 0x00000000         | Loop Counter 0 Registers          |
| DMAC_LC1_0     | 0x0410        | W           | 0x00000000         | Loop Counter 1 Registers          |
| DMAC_SAR1      | 0x0420        | W           | 0x00000000         | Source Address Registers          |
| DMAC_DAR1      | 0x0424        | W           | 0x00000000         | Destination Address Registers     |
| DMAC_CCR1      | 0x0428        | W           | 0x00000000         | Channel Control Registers         |
| DMAC_LC0_1     | 0x042c        | W           | 0x00000000         | Loop Counter 0 Registers          |
| DMAC_LC1_1     | 0x0430        | W           | 0x00000000         | Loop Counter 1 Registers          |
| DMAC_SAR2      | 0x0440        | W           | 0x00000000         | Source Address Registers          |
| DMAC_DAR2      | 0x0444        | W           | 0x00000000         | Destination Address Registers     |
| DMAC_CCR2      | 0x0448        | W           | 0x00000000         | Channel Control Registers         |
| DMAC_LC0_2     | 0x044c        | W           | 0x00000000         | Loop Counter 0 Registers          |
| DMAC_LC1_2     | 0x0450        | W           | 0x00000000         | Loop Counter 1 Registers          |
| DMAC_SAR3      | 0x0460        | W           | 0x00000000         | Source Address Registers          |
| DMAC_DAR3      | 0x0464        | W           | 0x00000000         | Destination Address Registers     |
| DMAC_CCR3      | 0x0468        | W           | 0x00000000         | Channel Control Registers         |
| DMAC_LC0_3     | 0x046c        | W           | 0x00000000         | Loop Counter 0 Registers          |
| DMAC_LC1_3     | 0x0470        | W           | 0x00000000         | Loop Counter 1 Registers          |
| DMAC_SAR4      | 0x0480        | W           | 0x00000000         | Source Address Registers          |
| DMAC_DAR4      | 0x0484        | W           | 0x00000000         | Destination Address Registers     |
| DMAC_CCR4      | 0x0488        | W           | 0x00000000         | Channel Control Registers         |
| DMAC_LC0_4     | 0x048c        | W           | 0x00000000         | Loop Counter 0 Registers          |
| DMAC_LC1_4     | 0x0490        | W           | 0x00000000         | Loop Counter 1 Registers          |
| DMAC_SAR5      | 0x04a0        | W           | 0x00000000         | Source Address Registers          |
| DMAC_DAR5      | 0x04a4        | W           | 0x00000000         | Destination Address Registers     |
| DMAC_CCR5      | 0x04a8        | W           | 0x00000000         | Channel Control Registers         |
| DMAC_LC0_5     | 0x04ac        | W           | 0x00000000         | Loop Counter 0 Registers          |
| DMAC_LC1_5     | 0x04b0        | W           | 0x00000000         | Loop Counter 1 Registers          |
| DMAC_SAR6      | 0x04c0        | W           | 0x00000000         | Source Address Registers          |
| DMAC_DAR6      | 0x04c4        | W           | 0x00000000         | Destination Address Registers     |
| DMAC_CCR6      | 0x04c8        | W           | 0x00000000         | Channel Control Registers         |
| DMAC_LC0_6     | 0x04cc        | W           | 0x00000000         | Loop Counter 0 Registers          |
| DMAC_LC1_6     | 0x04d0        | W           | 0x00000000         | Loop Counter 1 Registers          |
| DMAC_SAR7      | 0x04e0        | W           | 0x00000000         | Source Address Registers          |
| DMAC_DAR7      | 0x04e4        | W           | 0x00000000         | Destination Address Registers     |
| DMAC_CCR7      | 0x04e8        | W           | 0x00000000         | Channel Control Registers         |
| DMAC_LC0_7     | 0x04ec        | W           | 0x00000000         | Loop Counter 0 Registers          |
| DMAC_LC1_7     | 0x04f0        | W           | 0x00000000         | Loop Counter 1 Registers          |
| DMAC_DBGSTATUS | 0x0d00        | W           | 0x00000000         | Debug Status Register             |
| DMAC_DBGCMD    | 0x0d04        | W           | 0x00000000         | Debug Command Register            |

| Name          | Offset | Size | Reset Value | Description                  |
|---------------|--------|------|-------------|------------------------------|
| DMAC_DBGINST0 | 0x0d08 | W    | 0x00000000  | Debug Instruction-0 Register |
| DMAC_DBGINST1 | 0x0d0c | W    | 0x00000000  | Debug Instruction-1 Register |
| DMAC_CR0      | 0xe00  | W    | 0x00047051  | Configuration Register 0     |
| DMAC_CR1      | 0xe04  | W    | 0x00000057  | Configuration Register 1     |
| DMAC_CR2      | 0xe08  | W    | 0x00000000  | Configuration Register 2     |
| DMAC_CR3      | 0xe0c  | W    | 0x00000000  | Configuration Register 3     |
| DMAC_CR4      | 0xe10  | W    | 0x00000006  | Configuration Register 4     |
| DMAC_CRDn     | 0xe14  | W    | 0x02094733  | DMA Configuration Register   |
| DMAC_WD       | 0xe80  | W    | 0x00000000  | DMA Watchdog Register        |

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

#### 10.4.2 Detail Register Description

##### DMAC\_DSR

Address: Operational Base + offset (0x0000)

DMA Manager Status Register

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                              |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10 | RO   | 0x0         | reserved                                                                                                                                                                                                 |
| 9     | RO   | 0x0         | Provides the security status of the DMA manager thread:<br>0 = DMA manager operates in the Secure state<br>1 = DMA manager operates in the Non-secure state.                                             |
| 8:4   | RO   | 0x00        | When the DMA manager thread executes a DMAWFE instruction, it waits for the following event to occur:<br>b00000 = event[0]<br>b00001 = event[1]<br>b00010 = event[2]<br>...<br>b11111 = event[31].       |
| 3:0   | RO   | 0x0         | The operating state of the DMA manager:<br>b0000 = Stopped<br>b0001 = Executing<br>b0010 = Cache miss<br>b0011 = Updating PC<br>b0100 = Waiting for event<br>b0101-b1110 = reserved<br>b1111 = Faulting. |

##### DMAC\_DPC

Address: Operational Base + offset (0x0004)

DMA Program Counter Register

| Bit  | Attr | Reset Value | Description                                |
|------|------|-------------|--------------------------------------------|
| 31:0 | RO   | 0x00000000  | Program counter for the DMA manager thread |

##### DMAC\_INTEN

Address: Operational Base + offset (0x0020)

Interrupt Enable Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | <p>Program the appropriate bit to control how the DMAC responds when it executes DMASEV:</p> <p>Bit [N] = 0 If the DMAC executes DMASEV for the event-interrupt resource N then the DMAC signals event N to all of the threads. Set bit [N] to 0 if your system design does not use irq[N] to signal an interrupt request.</p> <p>Bit [N] = 1 If the DMAC executes DMASEV for the event-interrupt resource N then the DMAC sets irq[N] HIGH. Set bit [N] to 1 if your system designer requires irq[N] to signal an interrupt request.</p> |

**DMAC\_EVENT\_RIS**

Address: Operational Base + offset (0x0024)

Event-Interrupt Raw Status Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                           |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | <p>Returns the status of the event-interrupt resources:</p> <p>Bit [N] = 0 Event N is inactive or irq[N] is LOW.</p> <p>Bit [N] = 1 Event N is active or irq[N] is HIGH.</p> |

**DMAC\_INTMIS**

Address: Operational Base + offset (0x0028)

Interrupt Status Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | <p>Provides the status of the interrupts that are active in the DMAC:</p> <p>Bit [N] = 0 Interrupt N is inactive and therefore irq[N] is LOW.</p> <p>Bit [N] = 1 Interrupt N is active and therefore irq[N] is HIGH</p> |

**DMAC\_INTCLR**

Address: Operational Base + offset (0x002c)

Interrupt Clear Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | WO          | 0x00000000         | <p>Controls the clearing of the irq outputs:</p> <p>Bit [N] = 0 The status of irq[N] does not change.</p> <p>Bit [N] = 1 The DMAC sets irq[N] LOW if the INTEN Register programs the DMAC to signal an interrupt.</p> <p>Otherwise, the status of irq[N] does not change.</p> |

**DMAC\_FSRD**

Address: Operational Base + offset (0x0030)

Fault Status DMA Manager Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | <p>Provides the fault status of the DMA manager. Read as:</p> <p>0 = the DMA manager thread is not in the Faulting state</p> <p>1 = the DMA manager thread is in the Faulting state.</p> |

**DMAC\_FSRC**

Address: Operational Base + offset (0x0034)

Fault Status DMA Channel Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | Each bit provides the fault status of the corresponding channel.<br>Read as:<br>Bit [N] = 0 No fault is present on DMA channel N.<br>Bit [N] = 1 DMA channel N is in the Faulting or Faulting completing state. |

**DMAC\_FTRD**

Address: Operational Base + offset (0x0038)

Fault Type DMA Manager Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                              |
| 30         | RO          | 0x0                | If the DMA manager aborts, this bit indicates if the erroneous instruction was read from the system memory or from the debug interface:<br>0 = instruction that generated an abort was read from system memory<br>1 = instruction that generated an abort was read from the debug interface.                                                                          |
| 29:17      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                              |
| 16         | RO          | 0x0                | Indicates the AXI response that the DMAC receives on the RRESP bus, after the DMA manager performs an instruction fetch:<br>0 = OKAY response<br>1 = EXOKAY, SLVERR, or DECERR response                                                                                                                                                                               |
| 15:6       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                              |
| 5          | RO          | 0x0                | Indicates if the DMA manager was attempting to execute DMAWFE or DMASEV with inappropriate security permissions:<br>0 = DMA manager has appropriate security to execute DMAWFE or DMASEV<br>1 = a DMA manager thread in the Non-secure state attempted to execute either:<br>DMAWFE to wait for a secure event<br>DMASEV to create a secure event or secure interrupt |
| 4          | RO          | 0x0                | Indicates if the DMA manager was attempting to execute DMAGO with inappropriate security permissions:<br>0 = DMA manager has appropriate security to execute DMAGO<br>1 = DMA manager thread in the Non-secure state attempted to execute DMAGO to create a DMA channel operating in the Secure state.                                                                |
| 3:2        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                              |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1          | RO          | 0x0                | Indicates if the DMA manager was attempting to execute an instruction operand that was not valid for the configuration of the DMAC:<br>0 = valid operand<br>1 = invalid operand. |
| 0          | RW          | 0x0                | Indicates if the DMA manager was attempting to execute an undefined instruction:<br>0 = defined instruction<br>1 = undefined instruction.                                        |

**DMAC\_FTR0~DMAC\_FTR7**

Address: Operational Base + offset (0x0040)

Operational Base+0x44  
 Operational Base+0x48  
 Operational Base+0x4C  
 Operational Base+0x50  
 Operational Base+0x54  
 Operational Base+0x58  
 Operational Base+0x5C

Fault Type DMA Channel Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RO          | 0x0                | Indicates if the DMA channel has locked-up because of resource starvation:<br>0 = DMA channel has adequate resources<br>1 = DMA channel has locked-up because of insufficient resources.<br>This fault is an imprecise abort                                                                                                                                                            |
| 30         | RO          | 0x0                | If the DMA channel aborts, this bit indicates if the erroneous instruction was read from the system memory or from the debug interface:<br>0 = instruction that generated an abort was read from system memory<br>1 = instruction that generated an abort was read from the debug interface.<br>This fault is an imprecise abort but the bit is only valid when a precise abort occurs. |
| 29:19      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                |
| 18         | RO          | 0x0                | Indicates the AXI response that the DMAC receives on the RRESP bus, after the DMA channel thread performs a data read:<br>0 = OKAY response<br>1 = EXOKAY, SLVERR, or DECERR response.<br>This fault is an imprecise abort                                                                                                                                                              |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 17         | RO          | 0x0                | Indicates the AXI response that the DMAC receives on the BRESP bus, after the DMA channel thread performs a data write:<br>0 = OKAY response<br>1 = EXOKAY, SLVERR, or DECERR response.<br>This fault is an imprecise abort.                                                                                                                                                                     |
| 16         | RO          | 0x0                | Indicates the AXI response that the DMAC receives on the RRESP bus, after the DMA channel thread performs an instruction fetch:<br>0 = OKAY response<br>1 = EXOKAY, SLVERR, or DECERR response.<br>This fault is a precise abort.                                                                                                                                                                |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                         |
| 13         | RO          | 0x0                | Indicates if the MFIFO did not contain the data to enable the DMAC to perform the DMAST:<br>0 = MFIFO contains all the data to enable the DMAST to complete<br>1 = previous DMA LDs have not put enough data in the MFIFO to enable the DMAST to complete.<br>This fault is a precise abort.                                                                                                     |
| 12         | RO          | 0x0                | Indicates if the MFIFO prevented the DMA channel thread from executing DMA LD or DMA ST. Depending on the instruction:<br>DMA LD 0 = MFIFO contains sufficient space<br>1 = MFIFO is too small to hold the data that DMA LD requires.<br>DMA ST 0 = MFIFO contains sufficient data<br>1 = MFIFO is too small to store the data to enable DMA ST to complete.<br>This fault is an imprecise abort |
| 11:8       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                         |
| 7          | RO          | 0x0                | Indicates if a DMA channel thread, in the Non-secure state, attempts to program the CCRn Register to perform a secure read or secure write:<br>0 = a DMA channel thread in the Non-secure state is not violating the security permissions<br>1 = a DMA channel thread in the Non-secure state attempted to perform a secure read or secure write.<br>This fault is a precise abort               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6          | RO          | 0x0                | <p>Indicates if a DMA channel thread, in the Non-secure state, attempts to execute DMAWFP, DMALDP, DMASTP, or DMAFLUSHP with inappropriate security permissions:</p> <p>0 = a DMA channel thread in the Non-secure state is not violating the security permissions</p> <p>1 = a DMA channel thread in the Non-secure state attempted to execute either:</p> <ul style="list-style-type: none"> <li>o DMAWFP to wait for a secure peripheral</li> <li>o DMALDP or DMASTP to notify a secure peripheral</li> <li>o DMAFLUSHP to flush a secure peripheral.</li> </ul> <p>This fault is a precise abort.</p> |
| 5          | RO          | 0x0                | <p>Indicates if the DMA channel thread attempts to execute DMAWFE or DMASEV with inappropriate security permissions:</p> <p>0 = a DMA channel thread in the Non-secure state is not violating the security permissions</p> <p>1 = a DMA channel thread in the Non-secure state attempted to execute either:</p> <ul style="list-style-type: none"> <li>DMAWFE to wait for a secure event</li> <li>DMASEV to create a secure event or secure interrupt.</li> </ul> <p>This fault is a precise abort.</p>                                                                                                   |
| 4:2        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 1          | RO          | 0x0                | <p>Indicates if the DMA channel thread was attempting to execute an instruction operand that was not valid for the configuration of the DMAC:</p> <p>0 = valid operand</p> <p>1 = invalid operand.</p> <p>This fault is a precise abort.</p>                                                                                                                                                                                                                                                                                                                                                              |
| 0          | RO          | 0x0                | <p>Indicates if the DMA channel thread was attempting to execute an undefined instruction:</p> <p>0 = defined instruction</p> <p>1 = undefined instruction.</p> <p>This fault is a precise abort</p>                                                                                                                                                                                                                                                                                                                                                                                                      |

**DMAC\_CSR0~DMAC\_CSR7**

Address: Operational Base+0x100  
 Operational Base+0x108  
 Operational Base+0x110  
 Operational Base+0x118  
 Operational Base+0x120  
 Operational Base+0x128  
 Operational Base+0x130  
 Operational Base+0x138

## Channel Status Registers

| <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         | RO          | 0x0                | The channel non-secure bit provides the security of the DMA channel:<br>0 = DMA channel operates in the Secure state<br>1 = DMA channel operates in the Non-secure state                                                                                                                                                                                                                                                                              |
| 20:16      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 15         | RO          | 0x0                | When the DMA channel thread executes DMAWFP this bit indicates if the periph operand was set:<br>0 = DMAWFP executed with the periph operand not set<br>1 = DMAWFP executed with the periph operand set                                                                                                                                                                                                                                               |
| 14         | RO          | 0x0                | When the DMA channel thread executes DMAWFP this bit indicates if the burst or single operand were set:<br>0 = DMAWFP executed with the single operand set<br>1 = DMAWFP executed with the burst operand set.                                                                                                                                                                                                                                         |
| 13:9       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 8:4        | RO          | 0x00               | If the DMA channel is in the Waiting for event state or the Waiting for peripheral state then these bits indicate the event or peripheral number that the channel is waiting for:<br>b00000 = DMA channel is waiting for event, or peripheral, 0<br>b00001 = DMA channel is waiting for event, or peripheral, 1<br>b00010 = DMA channel is waiting for event, or peripheral, 2<br>...<br>b11111 = DMA channel is waiting for event, or peripheral, 31 |
| 3:0        | RO          | 0x0                | The channel status encoding is:<br>b0000 = Stopped<br>b0001 = Executing<br>b0010 = Cache miss<br>b0011 = Updating PC<br>b0100 = Waiting for event<br>b0101 = At barrier<br>b0110 = reserved<br>b0111 = Waiting for peripheral<br>b1000 = Killing<br>b1001 = Completing<br>b1010-b1101 = reserved<br>b1110 = Faulting completing<br>b1111 = Faulting                                                                                                   |

**DMAC\_CPC0~DMAC\_CPC7**

Address: Operational Base+0x104  
           Operational Base+0x10C  
           Operational Base+0x114  
           Operational Base+0x11c  
           Operational Base+0x124  
           Operational Base+0x12C  
           Operational Base+0x134  
           Operational Base+0x13C

## Channel Program Counter Registers

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                           |
|------------|-------------|--------------------|----------------------------------------------|
| 31:0       | RO          | 0x00000000         | Program counter for the DMA channel 0 thread |

**DMAC\_SAR0~DMAC\_SAR7**

Address: Operational Base+0x400  
 Operational Base+0x420  
 Operational Base+0x440  
 Operational Base+0x460  
 Operational Base+0x480  
 Operational Base+0x4A0  
 Operational Base+0x4C0  
 Operational Base+0x4E0

## Source Address Registers

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                           |
|------------|-------------|--------------------|----------------------------------------------|
| 31:0       | RO          | 0x00000000         | Address of the source data for DMA channel 0 |

**DMAC\_DAR0~DMAC\_DAR7**

Address: Operational Base+0x404  
 Operational Base+0x424  
 Operational Base+0x444  
 Operational Base+0x464  
 Operational Base+0x484  
 Operational Base+0x4A4  
 Operational Base+0x4C4  
 Operational Base+0x4E4

## Destination Address Registers

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                |
|------------|-------------|--------------------|---------------------------------------------------|
| 31:0       | RO          | 0x00000000         | Address of the Destination data for DMA channel 0 |

**DMAC\_CCR0~DMAC\_CCR7**

Address: Operational Base+0x408  
 Operational Base+0x428  
 Operational Base+0x448  
 Operational Base+0x468  
 Operational Base+0x488  
 Operational Base+0x4A8  
 Operational Base+0x4C8  
 Operational Base+0x4E8

## Channel Control Registers

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                               |
| 27:25      | RO          | 0x0                | Programs the state of AWCACHE[3,1:0]a when the DMAC writes the destination data.<br>Bit [27] 0 = AWCACHE[3] is LOW<br>1 = AWCACHE[3] is HIGH.<br>Bit [26] 0 = AWCACHE[1] is LOW<br>1 = AWCACHE[1] is HIGH.<br>Bit [25] 0 = AWCACHE[0] is LOW<br>1 = AWCACHE[0] is HIGH |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 24:22      | RO          | 0x0                | <p>Programs the state of AWPROT[2:0]a when the DMAC writes the destination data.</p> <p>Bit [24] 0 = AWPROT[2] is LOW<br/>1 = AWPROT[2] is HIGH.</p> <p>Bit [23] 0 = AWPROT[1] is LOW<br/>1 = AWPROT[1] is HIGH.</p> <p>Bit [22] 0 = AWPROT[0] is LOW<br/>1 = AWPROT[0] is HIGH</p>                                                                                                                                                                                                       |
| 21:18      | RO          | 0x0                | <p>For each burst, these bits program the number of data transfers that the DMAC performs when it writes the destination data:</p> <p>b0000 = 1 data transfer<br/>b0001 = 2 data transfers<br/>b0010 = 3 data transfers<br/>...<br/>b1111 = 16 data transfers.</p> <p>The total number of bytes that the DMAC writes out of the MFIFO when it executes a DMAST instruction is the product of dst_burst_len and dst_burst_size</p>                                                         |
| 17:15      | RO          | 0x0                | <p>For each beat within a burst, it programs the number of bytes that the DMAC writes to the destination:</p> <p>b000 = writes 1 byte per beat<br/>b001 = writes 2 bytes per beat<br/>b010 = writes 4 bytes per beat<br/>b011 = writes 8 bytes per beat<br/>b100 = writes 16 bytes per beat<br/>b101-b111 = reserved.</p> <p>The total number of bytes that the DMAC writes out of the MFIFO when it executes a DMAST instruction is the product of dst_burst_len and dst_burst_size.</p> |
| 14         | RO          | 0x0                | <p>Programs the burst type that the DMAC performs when it writes the destination data:</p> <p>0 = Fixed-address burst. The DMAC signals AWBURST[0] LOW.<br/>1 = Incrementing-address burst. The DMAC signals AWBURST[0] HIGH.</p>                                                                                                                                                                                                                                                         |
| 13:11      | RO          | 0x0                | <p>Set the bits to control the state of ARCACHE[2:0]a when the DMAC reads the source data.</p> <p>Bit [13] 0 = ARCACHE[2] is LOW<br/>1 = ARCACHE[2] is HIGH.</p> <p>Bit [12] 0 = ARCACHE[1] is LOW<br/>1 = ARCACHE[1] is HIGH.</p> <p>Bit [11] 0 = ARCACHE[0] is LOW<br/>1 = ARCACHE[0] is HIGH.</p>                                                                                                                                                                                      |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10:8       | RO          | 0x0                | <p>Programs the state of ARPROT[2:0]a when the DMAC reads the source data.</p> <p>Bit [10] 0 = ARPROT[2] is LOW<br/>1 = ARPROT[2] is HIGH.</p> <p>Bit [9] 0 = ARPROT[1] is LOW<br/>1 = ARPROT[1] is HIGH.</p> <p>Bit [8] 0 = ARPROT[0] is LOW<br/>1 = ARPROT[0] is HIGH.</p>                                                                                                                                                                                                  |
| 7:4        | RO          | 0x0                | <p>For each burst, these bits program the number of data transfers that the DMAC performs when it reads the source data:</p> <p>b0000 = 1 data transfer<br/>b0001 = 2 data transfers<br/>b0010 = 3 data transfers<br/>...<br/>b1111 = 16 data transfers.</p> <p>The total number of bytes that the DMAC reads into the MFIFO when it executes a DMA LD instruction is the product of src_burst_len and src_burst_size</p>                                                     |
| 3:1        | RO          | 0x0                | <p>For each beat within a burst, it programs the number of bytes that the DMAC reads from the source:</p> <p>b000 = reads 1 byte per beat<br/>b001 = reads 2 bytes per beat<br/>b010 = reads 4 bytes per beat<br/>b011 = reads 8 bytes per beat<br/>b100 = reads 16 bytes per beat<br/>b101-b111 = reserved.</p> <p>The total number of bytes that the DMAC reads into the MFIFO when it executes a DMA LD instruction is the product of src_burst_len and src_burst_size</p> |
| 0          | RO          | 0x0                | <p>Programs the burst type that the DMAC performs when it reads the source data:</p> <p>0 = Fixed-address burst. The DMAC signals ARBURST[0] LOW.<br/>1 = Incrementing-address burst. The DMAC signals ARBURST[0] HIGH</p>                                                                                                                                                                                                                                                    |

**DMAC\_LC0\_0~DMAC\_LC0\_7**

Address: Operational Base+0x40c  
 Operational Base+0x42C  
 Operational Base+0x44C  
 Operational Base+0x46C  
 Operational Base+0x48C  
 Operational Base+0x4AC  
 Operational Base+0x4CC  
 Operational Base+0x4EC

Loop Counter 0 Registers

| <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        | RO          | 0x00               | Loop counter 0 iterations |

**DMAC\_LC1\_0~DMAC\_LC1\_7**

Address: Operational Base + 0x410  
 Operational Base + 0x430  
 Operational Base + 0x450  
 Operational Base + 0x470  
 Operational Base + 0x490  
 Operational Base + 0x4B0  
 Operational Base + 0x4D0  
 Operational Base + 0x4F0

Loop Counter 1 Registers

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

**DMAC\_DBGSTATUS**

Address: Operational Base + offset (0x0d00)

Debug Status Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2       | RO          | 0x0                | reserved                                                                                                                                                           |
| 1:0        | RO          | 0x0                | The debug encoding is as follows:<br>b00 = execute the instruction that the DBGINST [1:0] Registers contain<br>b01 = reserved<br>b10 = reserved<br>b11 = reserved. |

**DMAC\_DBGCMD**

Address: Operational Base + offset (0x0d04)

Debug Command Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2       | RO          | 0x0                | reserved                                                                                                                                                          |
| 1:0        | WO          | 0x0                | The debug encoding is as follows:<br>b00 = execute the instruction that the DBGINST [1:0] Registers contain<br>b01 = reserved<br>b10 = reserved<br>b11 = reserved |

**DMAC\_DBGINST0**

Address: Operational Base + offset (0x0d08)

Debug Instruction-0 Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b> |
|------------|-------------|--------------------|--------------------|
| 31:24      | WO          | 0x00               | Instruction byte 1 |
| 23:16      | WO          | 0x00               | Instruction byte 0 |
| 15:11      | RO          | 0x0                | reserved           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------|
| 10:8       | WO          | 0x0                | DMA channel number:<br>b000 = DMA channel 0<br>b001 = DMA channel 1<br>b010 = DMA channel 2<br>...<br>b111 = DMA channel 7 |
| 7:1        | RO          | 0x0                | reserved                                                                                                                   |
| 0          | WO          | 0x0                | The debug thread encoding is as follows:<br>0 = DMA manager thread<br>1 = DMA channel.                                     |

**DMAC\_DBGINST1**

Address: Operational Base + offset (0x0d0c)

Debug Instruction-1 Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b> |
|------------|-------------|--------------------|--------------------|
| 31:24      | WO          | 0x00               | Instruction byte 5 |
| 23:16      | WO          | 0x00               | Instruction byte 4 |
| 15:8       | WO          | 0x00               | Instruction byte 3 |
| 7:0        | WO          | 0x00               | Instruction byte 2 |

**DMAC\_CRO**

Address: Operational Base + offset (0x0e00)

Configuration Register 0

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:22      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                |
| 21:17      | RO          | 0x02               | Number of interrupt outputs that the DMAC provides:<br>b00000 = 1 interrupt output, irq[0]<br>b00001 = 2 interrupt outputs, irq[1:0]<br>b00010 = 3 interrupt outputs, irq[2:0]<br>...<br>b11111 = 32 interrupt outputs, irq[31:0].                      |
| 16:12      | RO          | 0x07               | Number of peripheral request interfaces that the DMAC provides:<br>b00000 = 1 peripheral request interface<br>b00001 = 2 peripheral request interfaces<br>b00010 = 3 peripheral request interfaces<br>...<br>b11111 = 32 peripheral request interfaces. |
| 11:7       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                |
| 6:4        | RO          | 0x5                | Number of DMA channels that the DMAC supports:<br>b000 = 1 DMA channel<br>b001 = 2 DMA channels<br>b010 = 3 DMA channels<br>...<br>b111 = 8 DMA channels.                                                                                               |
| 3          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2          | RO          | 0x0                | Indicates the status of the boot_manager_ns signal when the DMAC exited from reset:<br>0 = boot_manager_ns was LOW<br>1 = boot_manager_ns was HIGH.                                                         |
| 1          | RO          | 0x0                | Indicates the status of the boot_from_pc signal when the DMAC exited from reset:<br>0 = boot_from_pc was LOW<br>1 = boot_from_pc was HIGH                                                                   |
| 0          | RO          | 0x1                | Supports peripheral requests:<br>0 = the DMAC does not provide a peripheral request interface<br>1 = the DMAC provides the number of peripheral request interfaces that the num_periph_req field specifies. |

**DMAC\_CR1**

Address: Operational Base + offset (0x0e04)

Configuration Register 1

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                                                                                                                                             |
| 7:4        | RO          | 0x5                | [7:4] num_i-cache_lines Number of i-cache lines:<br>b0000 = 1 i-cache line<br>b0001 = 2 i-cache lines<br>b0010 = 3 i-cache lines<br>...<br>b1111 = 16 i-cache lines. |
| 3          | RO          | 0x0                | reserved                                                                                                                                                             |
| 2:0        | RO          | 0x7                | The length of an i-cache line:<br>b000-b001 = reserved<br>b010 = 4 bytes<br>b011 = 8 bytes<br>b100 = 16 bytes<br>b101 = 32 bytes<br>b110-b111 = reserved             |

**DMAC\_CR2**

Address: Operational Base + offset (0x0e08)

Configuration Register 2

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | Provides the value of boot_addr[31:0] when the DMAC exited from reset |

**DMAC\_CR3**

Address: Operational Base + offset (0x0e0c)

Configuration Register 3

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                            |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | Provides the security state of an event-interrupt resource:<br>Bit [N] = 0 Assigns event<N> or irq[N] to the Secure state.<br>Bit [N] = 1 Assigns event<N> or irq[N] to the Non-secure state. |

**DMAC\_CR4**

Address: Operational Base + offset (0x0e10)

Configuration Register 4

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000006         | Provides the security state of the peripheral request interfaces:<br>Bit [N] = 0 Assigns peripheral request interface N to the Secure state.<br>Bit [N] = 1 Assigns peripheral request interface N to the Non-secure state |

**DMAC\_CRDn**

Address: Operational Base + offset (0x0e14)

DMA Configuration Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                                                                                                            |
| 29:20      | RO          | 0x020              | The number of lines that the data buffer contains:<br>b000000000 = 1 line<br>b000000001 = 2 lines<br>...<br>b111111111 = 1024 lines |
| 19:16      | RO          | 0x9                | The depth of the read queue:<br>b0000 = 1 line<br>b0001 = 2 lines<br>...<br>b1111 = 16 lines.                                       |
| 15         | RO          | 0x0                | reserved                                                                                                                            |
| 14:12      | RO          | 0x4                | Read issuing capability that programs the number of outstanding read transactions:<br>b000 = 1<br>b001 = 2<br>...<br>b111 = 8       |
| 11:8       | RO          | 0x7                | The depth of the write queue:<br>b0000 = 1 line<br>b0001 = 2 lines<br>...<br>b1111 = 16 lines.                                      |
| 7          | RO          | 0x0                | reserved                                                                                                                            |

| Bit | Attr | Reset Value | Description                                                                                                                                                 |
|-----|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6:4 | RO   | 0x3         | Write issuing capability that programs the number of outstanding write transactions:<br>b000 = 1<br>b001 = 2<br>...<br>b111 = 8                             |
| 3   | RO   | 0x0         | reserved                                                                                                                                                    |
| 2:0 | RO   | 0x3         | The data bus width of the AXI interface:<br>b000 = reserved<br>b001 = reserved<br>b010 = 32-bit<br>b011 = 64-bit<br>b100 = 128-bit<br>b101-b111 = reserved. |

**DMAC\_WD**

Address: Operational Base + offset (0x0e80)  
DMA Watchdog Register

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                  |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1 | RO   | 0x0         | reserved                                                                                                                                                                                     |
| 0    | RW   | 0x0         | Controls how the DMAC responds when it detects a lock-up condition:<br>0 = the DMAC aborts all of the contributing DMA channels and sets irq_abort HIGH<br>1 = the DMAC sets irq_abort HIGH. |

**10.5 Timing Diagram**

Following picture shows the relationship between dma\_req and dma\_ack.



Fig. 10-3 DMAC request and acknowledge timing

**10.6 Interface Description**

DMAC has the following tie-off signals. It can be configured by GRF register. (Please refer to the chapter to find how to configure)

Table 10-2 DMAC boot interface

| Interface       | Reset value | Control source |
|-----------------|-------------|----------------|
| boot_addr       | 0x0         | GRF            |
| boot_from_pc    | 0x0         | GRF            |
| boot_manager_ns | 0x1         |                |
| boot_irq_ns     | 0xffff      |                |

| Interface      | Reset value | Control source |
|----------------|-------------|----------------|
| boot_periph_ns | 0x3fff      |                |

Notes: *boot\_manager\_ns*, *boot\_irq\_ns* and *boot\_periph\_ns* can't be configured, so dmac can work under non-secure state only

### **boot\_addr**

Configures the address location that contains the first instruction the DMAC executes, when it exits from reset.

### **boot\_from\_pc**

Controls the location in which the DMAC executes its initial instruction, after it exits from reset:

0 = DMAC waits for an instruction from either APB interface

1 = DMA manager thread executes the instruction that is located at the address that

### **boot\_manager\_ns**

When the DMAC exits from reset, this signal controls the security state of the DMA manager thread:

0 = assigns DMA manager to the Secure state

1 = assigns DMA manager to the Non-secure state.

### **boot\_irq\_ns**

Controls the security state of an event-interrupt resource, when the DMAC exits from reset:

*boot\_irq\_ns[x]* is LOW

The DMAC assigns event<x> or irq[x] to the Secure state.

*boot\_irq\_ns[x]* is HIGH

The DMAC assigns event<x> or irq[x] to the Non-secure state.

### **boot\_periph\_ns**

Controls the security state of a peripheral request interface, when the DMAC exits from reset:

*boot\_periph\_ns[x]* is LOW

The DMAC assigns peripheral request interface x to the Secure state.

*boot\_periph\_ns[x]* is HIGH

The DMAC assigns peripheral request interface x to the Non-secure state.

## **10.7 Application Notes**

### **10.7.1 Using the APB slave interfaces**

DMAC can work under non-secure state only, and the secure APB interface is not used. So only the non-secure APB interface can be used to start or restart a DMA channel.

The necessary steps to start a DMA channel thread using the debug instruction registers as following:

1. Create a program for the DMA channel.
2. Store the program in a region of system memory.
3. Poll the DBGSTATUS Register to ensure that debug is idle, that is, the dbgstatus bit is 0.
4. Write to the DBGINST0 Register and enter the:
  - Instruction byte 0 encoding for DMAGO.
  - Instruction byte 1 encoding for DMAGO.
  - Debug thread bit to 0. This selects the DMA manager thread.
5. Write to the DBGINST1 Register with the DMAGO instruction byte [5:2] data, see Debug Instruction-1 Register o. You must set these four bytes to the address of the first instruction in the program, that was written to system memory in step 2.
6. Writing zero to the DBGCMD Register. The DMAC starts the DMA channel thread and sets the dbgstatus bit to 1.

### **10.7.2 Security usage**

#### **DMA manager thread is in the Non-secure state**

If the DNS bit is 1, the DMA manager thread operates in the Non-secure state, and it only performs non-secure instruction fetches. When a DMA manager thread in the Non-secure state processes:

#### **DMAGO**

The DMAC uses the status of the ns bit, to control if it starts a DMA channel thread. If:

ns = 0

The DMAC does not start a DMA channel thread and instead it:

1. Executes a NOP.
2. Sets the FSRD Register, see Fault Status DMA Manager
3. Sets the dmago\_err bit in the FTRD Register, see Fault Type DMA Manager Register.
4. Moves the DMA manager to the Faulting state.

ns = 1

The DMAC starts a DMA channel thread in the Non-secure state and programs the CNS bit to be non-secure.

#### **DMAWFE**

The DMAC uses the status of the corresponding INS bit, in the CR3 Register, to control if it waits for the event. If:

INS = 0

The event is in the Secure state. The DMAC:

1. Executes a NOP.
2. Sets the FSRD Register, see Fault Status DMA Manager Register.
3. Sets the mgr\_evnt\_err bit in the FTRD Register, see Fault Type DMA Manager Register.
4. Moves the DMA manager to the Faulting state.

INS = 1

The event is in the Non-secure state. The DMAC halts execution of the thread and waits for the event to occur.

#### **DMASEV**

The DMAC uses the status of the corresponding INS bit, in the CR3 Register, to control if it creates the event-interrupt. If:

INS = 0

The event-interrupt resource is in the Secure state. The DMAC:

1. Executes a NOP.
2. Sets the FSRD Register, see Fault Status DMA Manager Register.
3. Sets the mgr\_evnt\_err bit in the FTRD Register, see Fault Type DMA Manager Register.
4. Moves the DMA manager to the Faulting state.

INS = 1

The event-interrupt resource is in the Non-secure state. The DMAC creates the event-interrupt.

#### **DMA channel thread is in the Non-secure state**

When the CNS bit is 1, the DMA channel thread is programmed to operate in the Non-secure state and it only performs non-secure instruction fetches.

When a DMA channel thread in the Non-secure state processes the following instructions:

#### **DMAWFE**

The DMAC uses the status of the corresponding INS bit, in the CR3 Register, to control if it waits for the event. If:

INS = 0

The event is in the Secure state. The DMAC:

1. Executes a NOP.
2. Sets the appropriate bit in the FSRC Register that corresponds to the DMA channel number. See Fault Status DMA Channel Register.
3. Sets the ch\_evnt\_err bit in the FTRn Register, see Fault Type DMA Channel Registers.
4. Moves the DMA channel to the Faulting completing state.

INS = 1

The event is in the Non-secure state. The DMAC halts execution of the thread and waits for the event to occur.

#### **DMASEV**

The DMAC uses the status of the corresponding INS bit, in the CR3 Register, to control if it creates the event. If:

INS = 0

The event-interrupt resource is in the Secure state. The DMAC:

1. Executes a NOP.
2. Sets the appropriate bit in the FSRC Register that corresponds to the DMA channel number.  
See Fault Status DMA Channel Register.
3. Sets the ch\_evnt\_err bit in the FTRn Register, see Fault Type DMA Channel Registers .
4. Moves the DMA channel to the Faulting completing state.

INS = 1

The event-interrupt resource is in the Non-secure state. The DMAC creates the event-interrupt.

#### **DMAWFP**

The DMAC uses the status of the corresponding PNS bit, in the CR4 Register, to control if it waits for the peripheral to signal a request. If:

PNS = 0

The peripheral is in the Secure state. The DMAC:

1. Executes a NOP.
2. Sets the appropriate bit in the FSRC Register that corresponds to the DMA channel number.  
See Fault Status DMA Channel Register.
3. Sets the ch\_periph\_err bit in the FTRn Register, see Fault Type DMA Channel Registers.
4. Moves the DMA channel to the Faulting completing state.

PNS = 1

The peripheral is in the Non-secure state. The DMAC halts execution of the thread and waits for the peripheral to signal a request.

#### **DMALDP, DMASTP**

The DMAC uses the status of the corresponding PNS bit, in the CR4 Register, to control if it sends an acknowledgement to the peripheral. If:

PNS = 0

The peripheral is in the secure state. The DMAC:

1. Executes a NOP.
2. Sets the appropriate bit in the FSRC Register that corresponds to the DMA channel number.  
See Fault Status DMA Channel Register.
3. Sets the ch\_periph\_err bit in the FTRn Register, see Fault Type DMA Channel Registers.
4. Moves the DMA channel to the Faulting completing state.

PNS = 1

The peripheral is in the Non-secure state. The DMAC sends a message to the peripheral to communicate when the data transfer is complete.

#### **DMAFLUSHP**

The DMAC uses the status of the corresponding PNS bit, in the CR4 Register, to control if it sends a flush request to the peripheral. If:

PNS = 0

The peripheral is in the secure state. The DMAC:

1. Executes a NOP.
2. Sets the appropriate bit in the FSRC Register that corresponds to the DMA channel number.  
See Fault Status DMA Channel Register.
3. Sets the ch\_periph\_err bit in the FTRn Register, see Fault Type DMA Channel Registers.
4. Moves the DMA channel to the Faulting completing state.

PNS = 1

The peripheral is in the Non-secure state. The DMAC clears the state of the peripheral and sends a message to the peripheral to resend its level status.

When a DMA channel thread is in the Non-secure state, and a DMAMOV CCR instruction attempts to program the channel to perform a secure AXI transaction, the DMAC:

1. Executes a DMANOP.
2. Sets the appropriate bit in the FSRC Register that corresponds to the DMA channel number.  
See Fault Status DMA Channel Register.
3. Sets the ch\_rdwr\_err bit in the FTRn Register, see Fault Type DMA Channel Registers.
4. Moves the DMA channel thread to the Faulting completing state.

### **10.7.3 Programming restrictions**

#### **Fixed unaligned bursts**

The DMAC does not support fixed unaligned bursts. If you program the following conditions,

the DMAC treats this as a programming error:

Unaligned read

- src\_inc field is 0 in the CCRn Register
- the SARn Register contains an address that is not aligned to the size of data that the src\_burst\_size field contain

Unaligned write

- dst\_inc field is 0 in the CCRn Register
- the DARn Register contains an address that is not aligned to the size of data that the dst\_burst\_size field contains

### **Endian swap size restrictions**

If you program the endian\_swap\_size field in the CCRn Register, to enable a DMA channel to perform an endian swap then you must set the corresponding SARn Register and the corresponding DARn Register to contain an address that is aligned to the value that the endian\_swap\_size field contains.

### **Updating DMA channel control registers during a DMA cycle restrictions**

Prior to the DMAC executing a sequence of DMA LD and DMA ST instructions, the values you program in to the CCRn Register, SARn Register, and DARn Register control the data byte lane manipulation that the DMAC performs when it transfers the data from the source address to the destination address. You'd better not update these registers during a DMA cycle.

### **Resource sharing between DMA channels**

DMA channel programs share the MFIFO data storage resource. You must not start a set of concurrently running DMA channel programs with a resource requirement that exceeds the configured size of the MFIFO. If you exceed this limit then the DMAC might lock up and generate a Watchdog abort.

#### **10.7.4 Unaligned transfers may be corrupted**

For a configuration with more than one channel, if any of channels 1 to 7 is performing transfers between certain types of misaligned source and destination addresses, then the output data may be corrupted by the action of channel 0.

Data corruption might occur if all of the following are true:

1. Two beats of AXI read data are received for one of channels 1 to 7.
2. Source and destination address alignments mean that each read data beat is split across two lines in the data buffer (see Splitting data, below).
3. There is one idle cycle between the two read data beats.
4. Channel 0 performs an operation that updates channel control information during this idle cycle (see Updates to channel control information, below)

### **Splitting data**

Depending upon the programmed values for the DMA transfer, one beat of read data from the AXI interface need to be split across two lines in the internal data buffer. This occurs when the read data beat contains data bytes which will be written to addresses that wrap around at the AXI interface data width, so that these bytes could not be transferred by a single AXI write data beat of the full interface width.

Most applications of DMA-330 do not split data in this way, so are NOT vulnerable to data corruption from this defect.

The following cases are NOT vulnerable to data corruption because they do not split data:

- Byte lane offset between source and destination addresses is 0 when source and destination addresses have the same byte lane alignment, the offset is 0 and a wrap operation that splits data cannot occur.
- Byte lane offset between source and destination addresses is a multiple of source size

Table 10-3 Source size in CCRn

| <b>Source size in CCRn</b> | <b>Allowed offset between SARn and DARn</b> |
|----------------------------|---------------------------------------------|
| SS8                        | any offset allowed.                         |
| SS16                       | 0,2,4,6,8,10,12,14                          |
| SS32                       | 0,4,8,12                                    |
| SS64                       | 0,8                                         |

## 10.7.5 Interrupt shares between channel

As the DMAC does not record which channel (or list of channels) have asserted an interrupt. So it will depend on your program and whether any of the visible information for that program can be used to determine progress, and help identify the interrupt source.

There are 4 likely information sources that can be used to determine the progress made by a program:

- Program counter (PC)
- Source address
- Destination address
- Loop counters (LC)

For example, a program might emit an interrupt each time that it iterates around a loop. In this case, the interrupt service routine (ISR) would need to store the loop value of each channel when it is called, and then compare against the new value when it is next called. A change in value would indicate that the program has progressed.

The ISR must be carefully written to ensure that no interrupts are lost. The sequence of operations is as follows:

1. Disable interrupts
2. Immediately clear the interrupt in DMA-330
3. Check the relevant registers for both channels to determine which must be serviced
4. Take appropriate action for the channels
5. Re-enable interrupts and exit ISR

## 10.7.6 Instruction sets

Table 10-4 DMAC Instruction sets

| Mnemonic  | Instruction                 | Thread usage |
|-----------|-----------------------------|--------------|
| DMAADDH   | Add Halfword                | C            |
| DMAEND    | End                         | M/C          |
| DMAFLUSHP | Flush and notify Peripheral | C            |
| DMAGO     | Go                          | M            |
| DMAKILL   | Kill                        | C            |
| DMALD     | Load                        | C            |
| DMALDP    | Load Peripheral             | C            |
| DMALP     | Loop                        | C            |
| DMALPEND  | Loop End                    | C            |
| DMALPFE   | Loop Forever                | C            |
| DMAMOV    | Move                        | C            |
| DMANOP    | No operation                | M/C          |
| DMARMB    | Read Memory Barrier         | C            |
| DMASEV    | Send Event                  | M/C          |
| DMAST     | Store                       | C            |
| DMASTP    | Store and notify Peripheral | C            |
| DMASTZ    | Store Zero                  | C            |
| DMAWFE    | Wait For Event M            | M/C          |
| DMAWFP    | Wait For Peripheral         | C            |
| DMAWMB    | Write Memory Barrier        | C            |
| DMAADNH   | Add Negative Halfword       | C            |

Notes: Thread usage: C=DMA channel, M=DMA manager

## 10.7.7 Assembler directives

In this document, only DMMADNH instruction is took as an example to show the way the instruction assembled. For the other instructions, please refer to pl330\_trm.pdf.

### DMAADNH

Add Negative Halfword adds an immediate negative 16-bit value to the SARn Register or DARn Register, for the DMA channel thread. This enables the DMAC to support 2D DMA operations, or reading or writing an area of memory in a different order to naturally incrementing

addresses. See Source Address Registers and Destination Address Registers.

The immediate unsigned 16-bit value is one-extended to 32 bits, to create a value that is the two's complement representation of a negative number between -65536 and -1, before the DMAC adds it to the address using 32-bit addition. The DMAC discards the carry bit so that addresses wrap from 0xFFFFFFFF to 0x00000000. The net effect is to subtract between 65536 and 1 from the current value in the Source or Destination Address Register.

Following table shows the instruction encoding.

Table 10-5 DMAC instruction encoding

|           |          |   |   |   |   |   |   |    |   |
|-----------|----------|---|---|---|---|---|---|----|---|
| Imm[15:8] | Imm[7:0] | 0 | 1 | 0 | 1 | 1 | 1 | ra | 0 |
|-----------|----------|---|---|---|---|---|---|----|---|

### Assembler syntax

DMAADNH <address\_register>, <16-bit immediate>

where:

<address\_register>

Selects the address register to use. It must be either:

SAR

SARn Register and sets ra to 0.

DAR

DARn Register and sets ra to 1.

<16-bit immediate>

The immediate value to be added to the <address\_register>.

You should specify the 16-bit immediate as the number that is to be represented in the instruction encoding. For example, DMAADNH DAR, 0xFFFF causes the value 0xFFFF to be added to the current value of the Destination Address Register, effectively subtracting 16 from the DAR.

You can only use this instruction in a DMA channel thread.

### 10.7.8 MFIFO usage

For MFIFO usage, please refer to pl330\_trm.pdf

# Chapter 11 Process-Voltage-Temperature Monitor (PVTM)

## 11.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.
- Three PVTM blocks are supported:
  - core\_pvtm, used in pd\_core power domain
  - gpu\_pvtm, used in pd\_gpu power domain
  - video\_pvtm, used in pd\_video power domain

## 11.2 Block Diagram



Fig. 11-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.
- Freq\_cal, it is used to measure the frequency of clock which generated from the RING\_OSC block.

## 11.3 Function Description

### 11.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$ .

### 11.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 three PVTM control source and result destination.

Table 11-1 core\_pvtm control source and result destination

| Interface | Reset value | Control Source/Result Destination                              |
|-----------|-------------|----------------------------------------------------------------|
| xin24m    | 0x0         | CRU_CLKGATE10_CON[0], control the clock enable, active low     |
| resetn    | 0x1         | CRU_SOFT_RST1_CON[13] , reverse connect to resetn, active high |

| <b>Interface</b> | <b>Reset value</b> | <b>Control Source/Result Destination</b> |
|------------------|--------------------|------------------------------------------|
| start            | 0x0                | GRF_PVTM_CON0[0] , active high           |
| osc_ring_enable  | 0x0                | GRF_PVTM_CON0[1] , active high           |
| cal_cnt          | 0x0                | GRF_PVTM_CON1                            |
| freq_done        | 0x0                | GRF_PVTM_STATUS0[1]                      |
| freq_cnt         | 0x0                | GRF_PVTM_STATUS1                         |

Table 11-2 gpu\_pvtm control source and result destination

| <b>Interface</b> | <b>Reset value</b> | <b>Control Source/Result Destination</b>                      |
|------------------|--------------------|---------------------------------------------------------------|
| xin24m           | 0x0                | CRU_CLKGATE10_CON[1], control the clock enable, active low    |
| resetn           | 0x1                | CRU_SOFT_RST1_CON[10], reverse connect to resetn, active high |
| start            | 0x0                | GRF_PVTM_CON0[2], active high                                 |
| osc_ring_enable  | 0x0                | GRF_PVTM_CON0[3] , active high                                |
| cal_cnt          | 0x0                | GRF_PVTM_CON2                                                 |
| freq_done        | 0x0                | GRF_PVTM_STATUS0[0]                                           |
| freq_cnt         | 0x0                | GRF_PVTM_STATUS2                                              |

Table 11-3 video\_pvtm control source and result destination

| <b>Interface</b> | <b>Reset value</b> | <b>Control Source/Result Destination</b>                      |
|------------------|--------------------|---------------------------------------------------------------|
| xin24m           | 0x0                | CRU_CLKGATE10_CON[2], control the clock enable, active low    |
| resetn           | 0x1                | CRU_SOFT_RST1_CON[9] , reverse connect to resetn, active high |
| start            | 0x0                | GRF_PVTM_CON0[4] , active high                                |
| osc_ring_enable  | 0x0                | GRF_PVTM_CON0[5] , active high                                |
| cal_cnt          | 0x0                | GRF_PVTM_CON3                                                 |
| freq_done        | 0x0                | GRF_PVTM_STATUS0[3]                                           |
| freq_cnt         | 0x0                | GRF_PVTM_STATUS3                                              |

## 11.4 Application Notes

### 11.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. Configure the cal\_cnt to an appropriate value.
4. Set start '1' to calculate the cycles of the generated clock.
5. 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 12 EFUSE

### 12.1 Overview

RK3036 EFUSE is a parallel-in/parallel-out Electrical Fuse Macro IP which has 256 bits internal nonvolatile one-time programmable EFUSE storage. With a serial interface, 1-bit can be programmed each time in Program (PGM) mode and 8-bit can be read at one time in read mode.

The main features are as follows:

- One-time programmable nonvolatile EFUSE storage cells organized as 32x8 bit
- 1.1V typical core voltage
- The accumulative total time of  $1.21V < AVDD(\text{IO\_EFUSE\_VQPS}) \leq 2.75V$  must not exceed 1s
- Burning requirements:
  - 2.5V typical burning voltage( $AVDD(\text{IO\_EFUSE\_VQPS})$ ),  $AVDD(\text{IO\_EFUSE\_VQPS})$  must be high during PGM mode
  - 2us burning pulse width
  - Ambient temperature range of  $10\sim40^{\circ}\text{C}$

### 12.2 Block Diagram

In the following diagram, all the signals except power supply AVDD (IO\_EFUSE\_VQPS) and DVDD are controlled by registers. For detailed description, please refer to detailed register descriptions.



Fig. 12-1 EFUSE Block Diagram

### 12.3 Function Description

The EFUSE has three operation modes: PGM mode, Read mode, Inactive mode.

The EFUSE enters one of the three modes of operation determined by the logic level of read select signal (RDEN) and the program select (PGMEN). See following table for the corresponding logic levels and operation modes.

Table 12-1 EFUSE Operation Mode

| Mode          | PGMEN | RDEN | AVDD          | DVDD |
|---------------|-------|------|---------------|------|
| PGM mode      | H     | L    | H             | H    |
| Read mode     | L     | H    | L or Floating | H    |
| Inactive mode | L     | L    | L or Floating | H    |

#### Program (PGM) Mode

Before burning, initial Fuse output is "0", and written to "1" after burning. The EFUSE enters PGM mode if RDEN=L, PGMEN=H. When programming, EFUSE bit specified by address A[7:0] will be burnt by high pulse of AEN.

**Read Mode**

The EFUSE enters read mode if RDEN=H, PGMEN=L.

Address signals A[7]~A[5] are "invalid".

Table 12-2 EFUSE Read Mode

| A[4]~A[0] | D[0]     | D[1]     | D[2]     | D[3]      | D[4]      | D[5]      | D[6]      | D[7]      |
|-----------|----------|----------|----------|-----------|-----------|-----------|-----------|-----------|
| 00000     | Fuse[0]  | Fuse[32] | Fuse[64] | Fuse[96]  | Fuse[128] | Fuse[160] | Fuse[192] | Fuse[224] |
| 00001     | Fuse[1]  | Fuse[33] | Fuse[65] | Fuse[97]  | Fuse[129] | Fuse[161] | Fuse[193] | Fuse[225] |
| 00010     | Fuse[2]  | Fuse[34] | Fuse[66] | Fuse[98]  | Fuse[130] | Fuse[162] | Fuse[194] | Fuse[226] |
| 00011     | Fuse[3]  | Fuse[35] | Fuse[67] | Fuse[99]  | Fuse[131] | Fuse[163] | Fuse[195] | Fuse[227] |
| .         | .        | .        | .        | .         | .         | .         | .         | .         |
| .         | .        | .        | .        | .         | .         | .         | .         | .         |
| .         | .        | .        | .        | .         | .         | .         | .         | .         |
| 11111     | Fuse[31] | Fuse[63] | Fuse[95] | Fuse[127] | Fuse[159] | Fuse[191] | Fuse[223] | Fuse[255] |

**Inactive Mode**

The EFUSE enters inactive mode if neither PGM mode nor read mode is active. The preferred standby conditions in inactive mode are AEN=L, RDEN=L, PGMEN=L. D[7:0] are undefined in inactive mode.

## 12.4 Register Description

### 12.4.1 Registers Summary

| Name       | Offset | Size | Reset Value | Description             |
|------------|--------|------|-------------|-------------------------|
| EFUSE_CON  | 0x0000 | W    | 0x00000000  | EFUSE control register  |
| EFUSE_DATA | 0x0004 | W    | 0x00000000  | EFUSE data out register |

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

### 12.4.2 Detail Register Description

**EFUSE\_CON**

Address: Operational Base + offset (0x0000)

EFUSE control register

| Bit   | Attr | Reset Value | Description                                                                                                                                           |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RO   | 0x0         | reserved                                                                                                                                              |
| 15:8  | RW   | 0x00        | efuse_a<br>address input, A[0]~A[7].                                                                                                                  |
| 7:4   | RO   | 0x0         | reserved                                                                                                                                              |
| 3     | RW   | 0x0         | efuse_pgmen<br>program enable, low enable.<br>The efuse_pgmen was valid only when the grf_efuse_prg(bit[13] of register GRF_EFUSE_PRG) was set to "1" |
| 2     | RW   | 0x0         | efuse_rden<br>high to turn on sense amplifier and load data into latch.<br>Active-High (1.1v) for read mode; when PGM mode, must be set "low"(0v).    |
| 1     | RW   | 0x0         | efuse_aen<br>high to turn on the array for read or program access.                                                                                    |
| 0     | RO   | 0x0         | reserved                                                                                                                                              |

**EFUSE\_DATA**

Address: Operational Base + offset (0x0004)

EFUSE data out register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>            |
|------------|-------------|--------------------|-------------------------------|
| 31:8       | RO          | 0x0                | reserved                      |
| 7:0        | RO          | 0x00               | efuse_dout<br>EFUSE data out. |

**12.5 Timing Diagram**

- When EFUSE is in program(PGM) mode



Fig. 12-2 EFUSE Timing Diagram in PGM Mode

The following table shows the detailed requirements for timing parameters in the above diagram.

Table 12-3 EFUSE Timing Requirements in PGM Mode

| <b>Parameter</b>               | <b>Symbol</b>      | <b>Values</b>    |             |             | <b>Unit</b> |
|--------------------------------|--------------------|------------------|-------------|-------------|-------------|
|                                |                    | <b>Min.</b>      | <b>Typ.</b> | <b>Max.</b> |             |
| Burning time                   | $T_{PGM}$          | 2000             | 2000        | 10000       | ns          |
| Address enable cycle time      | $T_{AEN}$          | $T_{PGM} + 1900$ |             |             | ns          |
| Address to AEN setup time      | $T_{SP\_A}$        | 50               |             | —           | ns          |
| Address hold time from AEN     | $T_{HP\_A}$        | 50               |             | —           | ns          |
| PGMEN signal to AEN setup time | $T_{SP\_PGM}$      | 100              |             |             | ns          |
| AEN to PGMEN signal hold time  | $T_{HP\_PGM}$      | 100              |             |             | ns          |
| RDEN signal to AVDD setup time | $T_{SP\_RD}$       | 150              |             |             | ns          |
| AVDD to RDEN signal hold time  | $T_{HP\_RD}$       | 150              |             |             | ns          |
| AVDD to PGMEN setup time       | $T_{SP\_PG\_AVDD}$ | 1000             |             |             | ns          |
| PGMEN to AVDD hold time        | $T_{HP\_PG\_AVDD}$ | 1000             |             |             | ns          |

- When EFUSE is in read mode



Fig. 12-3 EFUSE Timing Diagram in Read Mode

The following table shows the detailed requirements for timing parameters in the above diagram.

Table 12-4 EFUSE Timing Requirements in Read Mode

| Parameter                              | Symbol         | Values        |      |      | Unit |
|----------------------------------------|----------------|---------------|------|------|------|
|                                        |                | Min.          | Typ. | Max. |      |
| Read time                              | $T_{RD}$       | 40            |      |      | ns   |
| Address enable cycle time              | $T_{AEN}$      | $T_{RD} + 35$ |      |      | ns   |
| Address to AEN setup time              | $T_{SR\_A}$    | 10            |      | —    | ns   |
| AEN to Address hold time               | $T_{HR\_A}$    | 10            |      | —    | ns   |
| DVDD to RDEN setup time                | $T_{SR\_DVDD}$ | 150           |      |      | ns   |
| RDEN to DVDD hold time                 | $T_{HR\_DVDD}$ | 150           |      |      | ns   |
| RDEN signal to AEN setup time          | $T_{SR\_RD}$   | 100           |      |      | ns   |
| Output data steady time with 0 loading | $T_{SQ}$       |               |      | 45   | ns   |
| Output data hold time                  | $T_{SQ\_H}$    | 0             |      |      | ns   |
| AEN to RDEN signal hold time           | $T_{HR\_RD}$   | 100           |      |      | ns   |

## 12.6 Application Notes

During usage of EFUSE, customers must pay more attention to the following items:

- (1) PGMEN and RDEN are not allowed to be high at the same time
- (2) AEN high is not allowed except in PGM mode or Read mode
- (3) A port (address) toggle is not allowed when AEN is high in PGM mode or Read mode
- (4) Neither Read mode transitioning to PGM mode directly nor PGM mode transitioning to Read mode directly is not allowed
- (5) For PGM mode converting to inactive mode, AVDD (IO\_EFUSE\_VQPS) must change from high to low or floating
- (6) AEN/PGMEN/RDEN signal must be held low until DVDD and AVDD supplies have reach their minimum values. DVDD should be set up earlier than AVDD. This prevents unintentional burning of the EFUSE macro during power-up.
- (7) The PGMEN was valid when the grf\_efuse\_prg (registers GRF\_EFUSE\_PRG[13] ) was set to "1".

## Chapter 13 WatchDog

### 13.1 Overview

Watchdog Timer (WDT) is an APB slave peripheral that can be used to prevent system lockup that may be caused by conflicting parts or programs in a SoC. The WDT would generate interrupt or reset signal when its counter reaches zero, then a reset controller would reset the system.

WDT supports the following features:

- 32 bits APB bus width
- WDT counter's clock is pclk
- 32 bits WDT counter width
- Counter counts down from a preset value to 0 to indicate the occurrence of a timeout
- WDT can perform two types of operations when timeout occurs:
  - Generate a system reset
  - First generate an interrupt and if this is not cleared by the service routine by the time a second timeout occurs then generate a system reset
- Programmable reset pulse length
- Total 16 defined ranges of main timeout period

### 13.2 Block Diagram



Fig. 13-1 WDT block diagram

#### Block Descriptions:

- APB Interface

The APB Interface implements the APB slave operation. Its data bus width is 32 bits.

- Register Block

A register block that reads coherence for the current count register.

- Interrupt & system reset control

An interrupt/system reset generation block is comprised of a decrementing counter and control logic.

### 13.3 Function Description

### 13.4 Operation

#### Counter

The WDT counts from a preset (timeout) value in descending order to zero. When the counter reaches zero, depending on the output response mode selected, either a system reset or an interrupt occurs. When the counter reaches zero, it wraps to the selected timeout value and continues decrementing. The user can restart the counter to its initial value. This is programmed by writing to the restart register at any time. The process of restarting the watchdog counter is sometimes referred to as kicking the dog. As a safety feature to prevent accidental restarts, the value 0x76 must be written to the Current Counter Value Register (WDT\_CRR).

#### Interrupts

The WDT can be programmed to generate an interrupt (and then a system reset) when a

timeout occurs. When a 1 is written to the response mode field (RMOD, bit 1) of the Watchdog Timer Control Register (WDT\_CR), the WDT generates an interrupt. If it is not cleared by the time a second timeout occurs, then it generates a system reset. If a restart occurs at the same time the watchdog counter reaches zero, an interrupt is not generated.

### System Resets

When a 0 is written to the output response mode field (RMOD, bit 1) of the Watchdog Timer Control Register (WDT\_CR), the WDT generates a system reset when a timeout occurs.

### Reset Pulse Length

The reset pulse length is the number of pclk cycles for which a system reset is asserted. When a system reset is generated, it remains asserted for the number of cycles specified by the reset pulse length or until the system is reset. A counter restart has no effect on the system reset once it has been asserted.

## 13.5 Programming sequence

Operation Flow Chart (Response mode=1)



1. Select required timeout period.
2. Set reset pulse length, response mode, and enable WDT.
3. Write 0x76 to WDT\_CRR.
4. Starts back to selected timeout period.
5. Can clear by reading WDT\_EOI or restarting (kicking) the counter by writing 0x76 to WDT\_CRR.

Fig. 13-2 WDT Operation Flow

## 13.6 Register Description

This section describes the control/status registers of the design.

### 13.6.1 Registers Summary

| Name     | Offset | Size | Reset Value | Description            |
|----------|--------|------|-------------|------------------------|
| WDT_CR   | 0x0000 | W    | 0x0000000a  | Control Register       |
| WDT_TORR | 0x0004 | W    | 0x00000000  | Timeout range Register |

| Name     | Offset | Size | Reset Value | Description                    |
|----------|--------|------|-------------|--------------------------------|
| WDT_CCVR | 0x0008 | W    | 0x00000000  | Current counter value Register |
| WDT_CRR  | 0x000c | W    | 0x00000000  | Counter restart Register       |
| WDT_STAT | 0x0010 | W    | 0x00000000  | Interrupt status Register      |
| WDT_EOI  | 0x0014 | W    | 0x00000000  | Interrupt clear Register       |

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

### 13.6.2 Detail Register Description

#### WDT\_CR

Address: Operational Base + offset (0x0000)

Control Register

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                      |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                         |
| 4:2  | RW   | 0x2         | <p>rst_pluse_lenth<br/>Reset pulse length.<br/>This is used to select the number of pclk cycles for which the system reset stays asserted.</p> <p>000: 2 pclk cycles<br/>001: 4 pclk cycles<br/>010: 8 pclk cycles<br/>011: 16 pclk cycles<br/>100: 32 pclk cycles<br/>101: 64 pclk cycles<br/>110: 128 pclk cycles<br/>111: 256 pclk cycles</p> |
| 1    | RW   | 0x1         | <p>resp_mode<br/>Response mode.<br/>Selects the output response generated to a timeout.<br/>0: Generate a system reset.<br/>1: First generate an interrupt and if it is not cleared by the time a second timeout occurs then generate a system reset.</p>                                                                                        |
| 0    | RW   | 0x0         | <p>wdt_en<br/>WDT enable<br/>0: WDT disabled;<br/>1: WDT enabled.</p>                                                                                                                                                                                                                                                                            |

#### WDT\_TORR

Address: Operational Base + offset (0x0004)

Timeout range Register

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

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0 | RW   | 0x0         | <p>timeout_period<br/>Timeout period.<br/>This field is used to select the timeout period from which the watchdog counter restarts. A change of the timeout period takes effect only after the next counter restart (kick).<br/>The range of values available for a 32-bit watchdog counter are:</p> <ul style="list-style-type: none"> <li>0000: 0x0000ffff</li> <li>0001: 0x0001ffff</li> <li>0010: 0x0003ffff</li> <li>0011: 0x0007ffff</li> <li>0100: 0x000fffff</li> <li>0101: 0x001fffff</li> <li>0110: 0x003fffff</li> <li>0111: 0x007fffff</li> <li>1000: 0x00ffffff</li> <li>1001: 0x01ffffff</li> <li>1010: 0x03ffffff</li> <li>1011: 0x07ffffff</li> <li>1100: 0x0fffffff</li> <li>1101: 0x1fffffff</li> <li>1110: 0x3fffffff</li> <li>1111: 0x7fffffff</li> </ul> |

**WDT\_CCVR**

Address: Operational Base + offset (0x0008)

Current counter value Register

| Bit  | Attr | Reset Value | Description                                                                                                                                                            |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | <p>cur_cnt<br/>Current counter value<br/>This register, when read, is the current value of the internal counter. This value is read coherently whenever it is read</p> |

**WDT\_CRR**

Address: Operational Base + offset (0x000c)

Counter restart Register

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                   |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                      |
| 7:0  | W1C  | 0x00        | <p>cnt_restart<br/>Counter restart<br/>This register is used to restart the WDT counter. As a safety feature to prevent accidental restarts, the value 0x76 must be written. A restart also clears the WDT interrupt. Reading this register returns zero.</p> |

**WDT\_STAT**

Address: Operational Base + offset (0x0010)

Interrupt status Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x0                | reserved                                                                                                                                          |
| 0          | RO          | 0x0                | wdt_status<br>This register shows the interrupt status of the WDT.<br>1: Interrupt is active regardless of polarity;<br>0: Interrupt is inactive. |

### **WDT\_EOI**

Address: Operational Base + offset (0x0014)

Interrupt clear Register

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x0                | reserved                                                                                                                          |
| 0          | RC          | 0x0                | wdt_int_clr<br>Clears the watchdog interrupt.<br>This can be used to clear the interrupt without restarting the watchdog counter. |

## **13.7 Application Notes**

Please refer to the function description section

## Chapter 14 System Debug

### 14.1 Overview

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

#### 14.1.1 Features

- Invasive debug with core halted
- SW-DP

#### 14.1.2 Debug components address map

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

| Module  | Base Address |
|---------|--------------|
| DAP_ROM | 0x20020000   |

### 14.2 Block Diagram



Fig. 14-1 Debug system structure

### 14.3 Function Description

#### 14.3.1 DAP

The DAP has following components:

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

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

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

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

More information please refer to the document CoreSight\_DAPLite\_TRM.pdf for the debug detail description.

### 14.4 Register Description

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

## 14.5 Interface Description

### 14.5.1 DAP SWJ-DP Interface

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



Fig. 14-2 DAP SWJ interface

### 14.5.2 DAP SW-DP Interface

This implementation is taken from ADIV5.1 and operates with a synchronous serial interface. This uses a single bidirectional data signal, and a clock signal.

The figure below describes the interaction between the timing of transactions on the serial wire interface, and the DAP internal bus transfers. It shows when the target responds with a WAIT acknowledgement.



Fig. 14-3 SW-DP acknowledgement timing

Table 14-1 SW-DP Interface Description

| Module pin | Direction | Pad name                   | IOMUX                                     |
|------------|-----------|----------------------------|-------------------------------------------|
| jtag_tck   | I         | IO_MMC0d2_JTAGtck_GPIO1c4  | GRF_GPIO1C_IOMUX[9:8]=2'b10 & mmc0_detn   |
| jtag_tm s  | I/O       | IO_MMC0d3_JTAGtms1_GPIO1c5 | GRF_GPIO1C_IOMUX[11:10]=2'b10 & mmc0_detn |

Note : mmc0\_detn, when high, no sd card is used.