



# A523 User Manual



Revision 1.1  
Jul.5, 2023

# Revision History

| Revision | Date          | Author  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------|---------------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1.0      | April 3, 2023 | AWA1896 | Initial Release Version                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 1.0.1    | May 12, 2023  | AWA1896 | Update the performance of the video decoding.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 1.1      | Jul.5, 2023   | AWA1896 | <p><b>About this document</b><br/>Add revision number definition</p> <p><b>Chapter 1 Production Description</b><br/>Update the features of some modules.</p> <p><b>Chapter 2 System</b></p> <ol style="list-style-type: none"><li>1. Update PLL distribution and some registers in section 2.5</li><li>2. Update IOMMU TLB enable register (offset: 0x0060) in section 2.9.</li><li>3. Update features in section 2.14.1 and add THS Temperature Conversion Formula in section 2.14.3.4.</li></ol> <p><b>Chapter 3 Memory</b><br/>SMHC module is updated.</p> <p><b>Chapter 4 Audio</b><br/>Update the features of Audio Codec and I2S/PCM.</p> <p><b>Chapter 7 Video Input Interfaces</b><br/>CSIC module is updated.</p> <p><b>Chapter 8 Interfaces</b></p> <ol style="list-style-type: none"><li>1. Update the Global Core Control Register (offset: 0xC110) in section 8.11.6.5</li><li>2. Update the features of the PCIe2.1 module and SPIFC module.</li><li>3. Update the block diagram of the PCIe2.1 module.</li><li>4. Update the PCIE SII Interrupt Mask Register1 (offset: 0xE04) and the PCIE SII Interrupt Register1 (offset: 0xE0C) in section 8.12.5.</li></ol> |

# About This Document

## Purpose and Scope

This document describes the features, logical structures, functions, operating modes, and related registers of each module about A523. For details about the interface timings and related parameters, the pins, pin usages, performance parameters, and package dimension, please refer to the *A523\_Datasheet*.

## Intended Audience

The document is intended for:

- Design and maintenance personnel for electronics
- Programmers in writing code or modifying the Allwinner provided code

## Revision Number Definition

This document is released based on the design completion products yet to be mass-produced. Therefore, the information in this document may be modified by reason of mass-produced verification.

All statements, information and recommendations in this document do not constitute any express or implied representation or warranty (including, but not limited to, the warranties of fitness for a particular purpose, merchantability, non-infringement, and accuracy and completeness of the document). Allwinner shall not be liable for any person's use of such information or/and this document.

If you have any questions about the document, please contact us to confirm and obtain the latest version.

## Symbol Conventions

The symbols that may be found in this document are defined as follows.

| Symbol                                                                                             | Description                                                                                   |
|----------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|
|  <b>WARNING</b> | A warning means that injury or death is possible if the instructions are not obeyed.          |
|  <b>CAUTION</b> | A caution means that damage to equipment is possible.                                         |
|  <b>NOTE</b>    | Provides additional information to emphasize or supplement important points of the main text. |

## Table Content Conventions

The table content conventions that may be found in this document are defined as follows.

| Symbol | Description        |
|--------|--------------------|
| -      | The cell is blank. |

## Reset Value Conventions

In the register definition tables:

If other column value in the row of a bit or multiple bits is “/”, this bit of these multiple bits are unused.

If the default value of a bit or multiple bits is “UDF”, this default value is undefined.

## Register Attributes

The register attributes that may be found in this document are defined as follows.

| Symbol | Description                                                                                                      |
|--------|------------------------------------------------------------------------------------------------------------------|
| R      | Read Only                                                                                                        |
| R/W    | Read/Write                                                                                                       |
| R/WAC  | Read/Write-Automatic-Clear, clear the bit automatically when the operation of complete. Writing 0 has no effect. |
| R/WC   | Read/Write-Clear                                                                                                 |
| R/W0C  | Read/Write 0 to Clear, Writing 1 has no effect                                                                   |
| R/W1C  | Read/Write 1 to Clear, Writing 0 has no effect                                                                   |
| R/W1S  | Read/Write 1 to Set, Writing 0 has no effect                                                                     |
| W      | Write Only                                                                                                       |

## Numerical System

The expressions of the data capacity, the frequency, and the data rate are described as follows.

| Type                 | Symbol | Value         |
|----------------------|--------|---------------|
| Data capacity        | K      | 1024          |
|                      | M      | 1,048,576     |
|                      | G      | 1,073,741,824 |
| Frequency, data rate | k      | 1000          |
|                      | M      | 1,000,000     |
|                      | G      | 1,000,000,000 |

The expressions of addresses and data are described as follows.

| Symbol | Example            | Description                                                                                                      |
|--------|--------------------|------------------------------------------------------------------------------------------------------------------|
| 0x     | 0x0200,0x79        | Address or data in hexadecimal                                                                                   |
| 0b     | 0b010,0b00 000 111 | Data or sequence in binary(register description is excluded.)                                                    |
| X      | 00X,XX1            | In data expression, X indicates 0 or 1. For example, 00X indicates 000 or 001, XX1 indicates 001,011,101 or 111. |



# Contents

|        |                            |    |
|--------|----------------------------|----|
| 1      | Product Description .....  | 7  |
| 1.1    | Overview .....             | 7  |
| 1.2    | Device Differences .....   | 7  |
| 1.3    | Features .....             | 8  |
| 1.3.1  | CPU Architecture .....     | 8  |
| 1.3.2  | GPU Architecture .....     | 8  |
| 1.3.3  | Memory Subsystem .....     | 8  |
| 1.3.4  | Video and Graphics .....   | 10 |
| 1.3.5  | Video Output .....         | 12 |
| 1.3.6  | Video Input .....          | 14 |
| 1.3.7  | System Peripherals .....   | 15 |
| 1.3.8  | Audio Subsystem .....      | 18 |
| 1.3.9  | Security System .....      | 20 |
| 1.3.10 | External Peripherals ..... | 22 |
| 1.3.11 | Package .....              | 30 |
| 1.4    | Block Diagram .....        | 31 |

# Figures

|                                                      |    |
|------------------------------------------------------|----|
| Figure 1-1 A523 System Block Diagram .....           | 31 |
| Figure 1-2 Medium and High-End Tablet Solution ..... | 32 |



# 1 Product Description

## 1.1 Overview

A523 series features high-performance platform processors for medium- and high-end tablets and interactive display applications. It integrates octa-core Cortex™-A55 CPU and G57 MC01 GPU to ensure rapid response and smooth running for daily applications, such as on-line video, web browsing, 3D game, and so on. A523 series also supports DDR3/DDR3L/DDR4/LPDDR3/LPDDR4/LPDDR4X, eMMC, NAND, SPI NAND, high-speed interfaces (PCIe2.1 and USB3.1 GEN1), multi video output interfaces (RGB/Dual-LVDS/2xMIPI-DSI/eDP), and video input interfaces (MIPI CSI). In addition, this chip family supports 4K@60fps H.265 decoder, 4K@25fps H.264 encoder, DI, and SmartColor system to provide users with outstanding experience. A523 series can be applied in the tablet PC market and the interactive terminal market.

## 1.2 Device Differences

The A523 series is configured with different sets of features in different devices. The feature differences across different devices are shown in the following table.

Table 1-1 Device Feature Differences

| Device       | Cortex™-A55 Speed Grade | Maximum Video Decoding Rate |                   |
|--------------|-------------------------|-----------------------------|-------------------|
|              |                         | H.265                       | VP9               |
| A523H00X0000 | 2.0 GHz                 | 4K@60fps, 10 bits           | 4K@60fps, 10 bits |
| A523M00X0000 | 1.8 GHz                 | 4K@30fps, 8bits             | 4K@30fps, 8bits   |



### NOTE

The terms "A523" and "A523 Series" are used in the following document to refer to the all devices listed in Table 1-1.

## 1.3 Features

### 1.3.1 CPU Architecture

- Octa-core ARM Cortex™-A55 in a DynamIQ big.LITTLE configuration, up to 2.0 GHz
  - 32 KB L1 I-cache and 32 KB L1 D-cache per A55 core
  - Optional 64KB L2 cache per “LITTLE” core
  - Optional 128KB L2 cache per “big” core
- Single-core RISC-V, up to 200 MHz
  - 16 KB I-cache and 16 KB D-cache
  - RV32IMAFC instructions

### 1.3.2 GPU Architecture

- ARM G57 MC01 GPU
- Supports OpenGL ES 3.2/2.0/1.1, Vulkan1.1/1.2/1.3, and OpenCL2.2
- Output and input format: 8-bit, 10-bit, and 16-bit YUV
- Anti-aliasing algorithm
- High memory bandwidth and low power consumption in 3D graphics processing
- AMBA4 AXI slave interface
- Latency tolerance
- Texture compression
- Configurable power management
- AFBC1.3
- Supports Digital Rights Management (DRM)

### 1.3.3 Memory Subsystem

#### 1.3.3.1 Boot ROM (BROM)

- On-chip memory
- Supports system boot from the following devices:
  - SD Card
  - eMMC
  - RAW NAND Flash
  - SPI NOR Flash (Single Mode and Quad Mode)

- SPI NAND Flash
- Supports mandatory upgrade process through USB or SD card
- Supports GPADC0 pin and eFuse module to select the boot media type
- Supports normal booting and secure booting
- Secure BROM loads only certified firmware
- Secure BROM ensures that the secure boot is a trusted environment

### 1.3.3.2 RAW NAND Flash

- Up to 80-bit ECC per 1024 bytes
- Supports 1K/2K/4K/8K/16K/32K bytes page size
- Up to 8-bit data bus width
- Supports SLC/MLC/TLC flash and EF-NAND
- Supports SDR, ONFI DDR1.0, Toggle DDR1.0, ONFI DDR2.0, and Toggle DDR2.0 RAW NAND FLASH

### 1.3.3.3 SDRAM

- 32-bit DDR3/DDR3L/DDR4/LPDDR3/LPDDR4/LPDDR4X interface
- Memory capacity up to 4GB
- 4 chip select lines for LPDDR3, LPDDR4, and LPDDR4X (especially the 64-bit LPDDR3, LPDDR4, and LPDDR4X)
- Clock frequency up to 1066 MHz for DDR3, DDR3L, and LPDDR3
- Clock frequency up to 1200 MHz for DDR4, LPDDR4, and LPDDR4x

### 1.3.3.4 SMHC

- Three SD/MMC host controller (SMHC) interfaces
  - SMHC0, compliant with the protocol Secure Digital Memory (SD3.0)
  - SMHC1, compliant with the protocol Secure Digital I/O (SDIO3.0)
  - SMHC2, compliant with the protocol Multimedia Card (eMMC5.1)
- The SMHC0 and the SMHC1 support the following:
  - 1-bit or 4-bit data width
  - Maximum performance:
    - SDR mode 200 MHz@1.8 V IO pad
    - DDR mode 50 MHz@1.8 V IO pad

- SDR mode 50 MHz@3.3 V IO pad
- The SMHC2 supports the following:
  - 1-bit, 4-bit, or 8-bit data width
  - Supports HS400 mode and HS200 mode
  - Maximum performance
    - SDR mode 200MHz@1.8V IO pad
    - DDR mode 200MHz@1.8V IO pad
    - SDR mode 50MHz@3.3V IO pad
    - DDR mode 50MHz@3.3V IO pad
- Support block size of 1 to 65535 bytes
- Support hardware CRC generation and error detection

### 1.3.4 Video and Graphics

#### 1.3.4.1 Display Engine (DE)

- Output size up to 4096 x 2048
- Supports seven alpha blending channels for main display and two display outputs
- Supports four overlay layers in each channel, and has an independent scaler
- Supports potter-duff compatible blending operation
- Supports AFBC buffer decoder
- Supports vertical keystone correction
- Input format
  - Semi-planar of YUV422/YUV420/YUV411/P010/P210
  - Planar of YUV422/YUV420/ YUV411
  - ARGB8888/XRGB8888/RGB888/ARGB4444/ ARGB1555/RGB565
- Output format: 8-bit or 10-bit YUV444/YUV422/YUV420/RGB444
- Frame Packing/Top-and-Bottom/Side-by-Side Full/Side-by-Side Half 3D format data
- 10-bit processing path for HDR video
- SmartColor5.0 for excellent display experience
  - Adaptive de-noising for compression noise or mosquito noise with yuv420/422 input
  - Adaptive super resolution scaler
  - Adaptive local dynamic contrast enhancement
  - Adaptive detail/edge enhancement

- Adaptive color enhancement (blue-stretch, green-stretch, and fresh tone correction) and skin tone protection
- Hue gain, saturation gain, and value gain controller
- Fully programmable color matrix
- Dynamic gamma
- Supports write back for high efficient dual display and miracast
- Supports register configuration queue for register update function

#### 1.3.4.2 De-interlacer (DI)

- Only off-line processing mode
- Video resolution from 32x32 to 2048x1280 pixel
- Input data format: 8-bit NV12/NV21/YV12 and planar YUV422/planar YUV422 UV-combined
- Output data format
  - 8-bit NV12/NV21/YV12 and planar YUV422/planar YUV422 UV-combined for DIT
  - YV12/planar YUV422 for TNR
- Weave/pixel-motion-adaptive de-interlace method
- Temporal noise reduction
- Film mode detection with video-on-film detection
- Performance
  - Module clock 120MHz for 1080P@60Hz YUV420 with all functions enable
  - Module clock 150MHz for 1080P@60Hz YUV422 with all functions enable

#### 1.3.4.3 Graphic 2D (G2D)

- Layer size up to 2048x2048 pixels
- Input format and output format contain the following:
  - YUV422 (semi-planar and planar format)
  - YUV420 (semi-planar and planar format)
  - P010, P210, P410, and Y8
  - ARGB8888, XRGB8888, RGB888, ARGB4444, ARGB1555, ARGB2101010, and RGB565
- Multiple rotation types
  - Horizontal flip and vertical flip
  - 0, 90, 180, or 270 degrees' rotation in clockwise direction

#### 1.3.4.4 Video Engine

##### Video Decoding

- Supports ITU-T H.265 Main/Main10, level 6.1
  - Maximum video resolution: 8192x4320
  - Maximum decoding rate: 3840x2160@60fps, 10 bits
- Supports VP9 Profile0/ Profile2, level 6.1
  - Maximum video resolution: 8192 x 4320
  - Maximum decoding rate: 3840x2160@60fps, 10 bits
- Supports ITU-T H.264 Base/Main/High Profile@Level 4.2
  - Maximum video resolution: 3840 x 2160
  - Maximum decoding rate: 3840x2160@30fps, 8 bits

##### Video Encoding

- H.264 BP/MP/HP encoding
  - Supports 4K@25fps@8bits
  - Maximum resolution: 4096 x 4096 (16 megapixels)
  - Supports I/P frame type
  - Supports CBR, VBR and FIXEDQP modes
  - Supports region of interest(ROI) encoding, a maximum of eight ROIs
- JPEG baseline encoding
  - JPEG encoder supports 4K@15fps
  - JPEG encoder supports YUV420, YUV422 and YUV444 format
- MJPEG baseline encoding up to 4K@15fps

#### 1.3.5 Video Output

##### 1.3.5.1 eDP1.3

- Up to 2.5K@60fps
- 1-lane, 2-lane, or 4-lane transmission, up to 2.7 Gbit/s per lane
- Video formats: RGB, YCbCr4:4:4, and YCbCr4:2:2
- Color depth: 8-bit and 10-bit per channel
- Supports I2S interface
  - Supports mono sound, stereo sound, and 7.1 surround sound

- Maximum sampling rate: 192 KHz
- Full link training
- Hot plug detection
- AUX channel
  - Maximum working frequency: 1MHz
  - Adopts Manchester-II encoding
- Clock spread spectrum
- Programmable voltage swing and pre-emphasis
- Embedded ESD

### 1.3.5.2 MIPI DSI

- Compliance with MIPI DSI V1.02
- Up to 1.5 Gbit/s for each lane
- Supports 4-lane MIPI DSI, up to 1280 x 720@60fps and 1920 x 1200@60fps
- Supports 4+4-lane MIPI DSI, up to 2560 x 1600@60fps
- Supports non-burst mode with sync pulse/sync event and burst mode
- Pixel format: RGB888, RGB666, RGB666 loosely packed and RGB565
- Supports continuous and non-continuous lane clock modes
- Generic commands support bidirectional communication in LP through data lane 0
- Supports low power data transmission
- Supports ULPS and escape modes
- Supports hardware checksum

### 1.3.5.3 TCON LCD

- Two TCON LCD controllers: TONC\_LCD0 and TCON\_LCD1
- TCON\_LCD0 supports the following
  - Supports RGB interface with DE/SYNC mode, up to 1920 x 1080@60fps
  - Supports serial RGB/dummy RGB interface, up to 800 x 480@60fps
  - Supports LVDS interface with dual link, up to 1920 x 1080@60fps
  - Supports LVDS interface with single link, up to 1366 x 768@60fps
  - Dither function for RGB888, RGB666, and RGB565
  - Supports i8080 interface, up to 800 x 480@60fps

- Supports BT656 interface for NTSC and PAL
- Supports MIPI DSI interface with dual link, up to 2560x1600@60fps
- Supports MIPI DSI interface with single link, up to 1920x1200@60fps
- TCON\_LCD1 supports MIPI DSI interface with single link, up to 1920x1200@60fps

#### 1.3.5.4 TCON TV

- One TCON TV controller (TCON\_TV1) for eDP1.3
- Up to 2.5K@60Hz
- Output format:
  - 8-bit or 10-bit pixel depth
  - HV

#### 1.3.6 Video Input

##### 1.3.6.1 ISP

- Supports one individual image signal processor(ISP), with maximum resolution of 3264x4224 in online mode
- Maximum frame rate of 8M@30fps 2F-WDR
- Supports off-line mode
- Supports WDR spilt, 2F-WDR line-based stitch, dynamic range compression (DRC), tone mapping, digital gain, gamma correction, defect pixel correction (DPC), cross talk correction (CTC), and chromatic aberration correction (CAC)
- Supports 2D/3D noise reduction, bayer interpolation, sharpen, white balance, and color enhancement
- Adjustable 3A functions: automatic white balance (AWB), automatic exposure (AE), and automatic focus (AF)
- Supports anti-flick detection statistics, and histogram statistics

##### 1.3.6.2 VIPP

- Four VIPP YUV422 or YUV420 outputs
- Maximum resolution of 3264x4224
- Each VIPP has one sub-VIPP in online mode
- Each VIPP has maximum four sub-VIPPs for time division multiplexing in offline mode
- Each Sub-VIPP supports the following:

- Crop
- 1 to 1/16 scaling for height and width
- 16 ORLs
- Supports graphics mirror and flip

### 1.3.6.3 MIPI CSI

- 8M@30fps RAW12 2F-WDR, size up to 3264(H) x 2448(V)
- 4+4-lane, 4+2+2-lane, or 2+2+2+2-lane MIPI Interface
  - MIPI CSI2 V1.1
  - MIPI DPHY V1.1
  - 2.0 Gbit/s per lane
- Crop function
- Frame-rate decreasing via software
- 4 DMA controllers for 4 video stream storage
  - Conversion of interlaced input to progressive output (anti-aliasing and noise reduction are not supported)
  - Data conversion supports: YUV422 to YUV420, YUV422 to YUV400, YUV420 to YUV400
  - Horizontal and vertical flip

### 1.3.6.4 Parallel CSI

- 16-bit digital camera interface
- Supports 8/10/12/16-bit width
- Supports BT.656, BT.601, BT.1120 interface
- Dual Data Rate (DDR) sample mode with pixel clock up to 148.5MHz
- Supports ITU-R BT.656 up to 4\*720P@30fps
- Supports ITU-R BT.1120 up to 4\*1080P@30fps

## 1.3.7 System Peripherals

### 1.3.7.1 Clock Controller Unit (CCU)

- 10 PLLs
- One on-chip RC oscillator
- Supports one external 24 MHz DCXO and one external 32.768 kHz oscillator

- Supports clock configuration and clock generation for corresponding modules
- Supports software-controlled clock gating and software-controlled reset for corresponding modules

#### 1.3.7.2 DMAC

- Up to 16-ch DMA in CPUX domain and 16-ch DMA in CPUS domain
- Provides 53 peripheral DMA requests for data reading and 53 peripheral DMA requests for data writing
- Transferring data with linked list
- Flexible data width: 8 bits, 16 bits, or 32 bits
- Programmable DMA burst length
- DRQ response includes waiting mode and handshake mode
- Supports non-aligned transform for memory devices
- DMA channels that support the following:
  - Pausing DMA
  - BMODE and I/O speed mode
  - DMA timeout

#### 1.3.7.3 I/O Memory Management Unit (IOMMU)

- Supports virtual address to physical address mapping by hardware implementation
- Supports ISP, CSI, VE\_MBUS0, VE\_MBUS1, G2D, DE, and DI parallel address mapping
- Supports ISP, CSI, VE\_MBUS0, VE\_MBUS1, G2D, DE, and DI bypass function independently
- Supports ISP, CSI, VE\_MBUS0, VE\_MBUS1, G2D, DE, and DI pre-fetch independently
- Supports ISP, CSI, VE\_MBUS0, VE\_MBUS1, G2D, DE, and DI interrupt handing mechanism independently
- Supports 2 levels TLB (level1 TLB for special using, and level2 TLB for sharing)
- Supports TLB Fully cleared and Partially disabled
- Supports trigger PTW behavior when TLB miss
- Supports checking the permission

#### 1.3.7.4 Message Box (MSGBOX)

- Supports communication between two CPUs through one way channels. Each CPU has one MSGBOX and can only read or write in one communication

- CPUX\_MSGBOX: CPUS/RISC-V write; ARM CPU read
- CPUS\_MSGBOX: ARM CPU/RISC-V write; CPUS read
- RISCV\_MSGBOX: ARM CPU/CPUS write; RISC-V read
- The channel between two CPU has 4 channels, and the FIFO depth of a channel is 8 x 32 bits
- Supports interrupts

#### 1.3.7.5 Power Reset Clock Management (PRCM)

- Two PRCMs in CPUS domain: PRCM and MCU\_PRCM
- 1 PLL
- CPUS Clock Configuration
- APBS Clock Configuration
- CPUS Module Clock Configuration
- CPUS Module BUS Gating and Reset
- RAM configure Control for PRCM

#### 1.3.7.6 RTC

- Provides a 16-bit counter for counting day, 5-bit counter for counting hour, 6-bit counter for counting minute, 6-bit counter for counting second
- External connect a 32.768 kHz low-frequency oscillator for count clock
- Timer frequency is 1 kHz
- Configurable initial value by software anytime
- Supports fanout function of internal 32K clock
- Supports timing alarm, and generates interrupt and wakeup the external devices
- 8 general purpose registers for storing power-off information in AON domain

#### 1.3.7.7 Spinlock

- Supports 32 lock units
- Two kinds of lock status: locked and unlocked
- Lock time of the processor is predictable (less than 200 cycles)

#### 1.3.7.8 Thermal Sensor Controller (THS)

- Two THS controllers
  - THS0, including TSENSOR4

- THS1, including TSENSOR0, TSENSOR1, and TSENSOR2
- Temperature accuracy:  $\pm 5^{\circ}\text{C}$  from  $-40^{\circ}\text{C}$  to  $60^{\circ}\text{C}$ ,  $\pm 3^{\circ}\text{C}$  from  $-60^{\circ}\text{C}$  to  $+125^{\circ}\text{C}$
- Averaging filter for thermal sensor reading
- Supports over-temperature protection interrupt and over-temperature alarm interrupt

### 1.3.7.9 Timer

- Configurable counting clock: 32KHz, 24MHz, 16MHz, or 200MHz
- Programmable 56-bit down timer
- Two working modes: periodic mode and single count mode
- Generates an interrupt when the count is decreased to 0

### 1.3.7.10 Watchdog Timer (WDT)

- Supports 12 initial values
- Supports the generation of timeout interrupts
- Supports the generation of reset signals
- Supports Watchdog Restart

## 1.3.8 Audio Subsystem

### 1.3.8.1 Audio Codec

- Two audio digital-to-analog converter (DAC) channels
  - 16-bit and 20-bit sample resolution
  - 8 kHz to 192 kHz DAC sample rate
  - $100 \pm 2 \text{ dB SNR@A-weight}$ ,  $-85 \pm 3 \text{ dB THD+N}$
- Three audio outputs
  - One stereo headphone output: HPOUTL/R
  - Two differential lineout outputs: LINEOUTLP/N and LINEOUTRP/N
- Three audio analog-to-digital converter (ADC) channels
  - 16-bit and 20-bit sample resolution
  - 8 kHz to 48 kHz ADC sample rate
  - $95 \pm 3 \text{ dB SNR@A-weight}$ ,  $-80 \pm 3 \text{ dB THD+N}$
- Three differential microphone inputs: MICIN1P/1N, MICIN2P/2N, and MICIN3P/3N (for echo reduction)

- Two low-noise analog microphone bias outputs: MBIAS and HBIAS
- Supports Dynamic Range Controller adjusting the DAC playback and ADC recording
- One 128x20-bits FIFO for DAC data transmit, one 128x20-bits FIFO for ADC data receive
- Programmable FIFO thresholds
- Supports interrupts and DMA
- Internal ALDO output for AVCC

### 1.3.8.2 I2S/PCM

- Four I2S/PCM external interfaces (I2S0, I2S1, I2S2, and I2S3) for connecting external power amplifier and MIC ADC
- Compliant with standard Philips Inter-IC sound (I2S) bus specification
  - Left-justified, Right-justified, PCM mode, and Time Division Multiplexing (TDM) format
  - Programmable PCM frame width: 1 BCLK width (short frame) and 2 BCLKs width (long frame)
- FIFOs for transmitting and receiving data
  - Programmable FIFO thresholds
  - 128 depth x 32-bit width TXFIFO and 64 depth x 32-bit width RXFIFO
- Supports multiple function clocks
  - Clock up to 24.576 MHz Data Output of I2S/PCM in Master mode (Only if the IO PAD and Peripheral I2S/PCM satisfy Timing Parameters)
  - Clock up to 12.288 MHz Data Input of I2S/PCM in Master mode
- Supports TX/RX DMA slave interface
- Supports multiple application scenarios
  - Up to 16 channels ( $f_s = 48 \text{ kHz}$ ) which has adjustable width from 8-bit to 32-bit
  - Sample rate from 8 kHz to 384 kHz ( $\text{sample rate} * \text{channel} * \text{slot width} \leq 24.576 \text{ MHz}$ )
  - 8-bit u-law and 8-bit A-law companded sample
- Supports master/slave mode

### 1.3.8.3 DMIC

- Supports maximum 8 digital PDM microphones
- Supports sample rate from 8 kHz to 48 kHz

#### 1.3.8.4 One Wire Audio (OWA)

- One OWA TX and One OWA RX
- Compliance with S/PDIF interface
- IEC-60958 and IEC-61937 transmitter and receiver functionality
- IEC-60958 supports data formats: 16 bits, 20 bits, and 24 bits
- TXFIFO and RXFIFO
  - One 128×24bits TXFIFO and one 64×24bits RXFIFO for audio data transfer
  - Programmable FIFO thresholds
- Supports TX/RX DMA slave interface
- Multiple function clock
  - Separate clock for OWA TX and OWA RX
  - The clock of TX function includes 24.576 MHz and 22.5792 MHz
  - The clock of RX function includes 24.576\*8 MHz
- Supports Hardware Parity On TX/RX
  - Hardware Parity generation on the transmitter
  - Hardware Parity checking on the receiver
- Supports channel status capture on the receiver
- Supports channel sample rate capture on the receiver
- Supports insertion detection for the receiver
- Supports channel status insertion for the transmitter

### 1.3.9 Security System

#### 1.3.9.1 Crypto Engine (CE)

- Symmetrical algorithm:
  - AES symmetrical algorithm
    - Key size: 128/192/256 bits
    - CFB mode includes: CFB1, CFB8, CFB64, and CFB128
    - CTR mode includes: CTR16, CTR32, CTR64, and CTR128
    - Supports ECB, CBC, CTS, OFB, CBC-MAC, and GCM modes
  - DES symmetrical algorithm
    - CTR mode, includes: CTR16, CTR32, and CTR64

- Supports ECB, CBC, and CBC-MAC mode
- Supports 3DES
- SM4 symmetrical algorithm supports ECB and CBC mode
- Hash algorithms
  - Support MD5, SHA1, SHA224, SHA256, SHA384, SHA512, and SM3
  - Support HMAC-SHA1, HMAC-SHA256
- Random bit generator algorithms
  - Support PRNG, 175 bits seed width, and output with multiple of 5 words
  - Support TRNG, post-process by hardware with SHA256, output with multiple of 8 words
- Public key algorithms
  - Support RSA public key algorithms: 512/1024/2048/3072/4096-bit width
  - Support ECC public key algorithms: 160/224/256/384/521-bit width
  - Support SM2 algorithms

#### 1.3.9.2 Security ID (SID)

- 4 Kbits eFuse
- Supports secure and non-secure world in eFuse
- The register configuration of SID is always in non-secure world
- Backup eFuse information by using SID\_SRAM
- One-time programming
- Selecting double-bit check by parameter definition
- Data scrambling
- Reading and writing protection

#### 1.3.9.3 Secure Memory Control (SMC)

- The SMC is always secure, only secure CPUX can access the SMC
- Sets secure area of DRAM
- Supports Master and address protection
- Sets secure property that Master accesses to DRAM
- Sets DRAM area
- Maximum 16 regions and Master has access to each region

#### 1.3.9.4 Secure Peripherals Control (SPC)

- The SPC is always secure, only secure CPU can access the SPC
- Sets secure property of peripherals

### 1.3.10 External Peripherals

#### 1.3.10.1 CIR Receiver (CIR\_RX)

- One CIR\_RX interface in CPUX domain and one CIR\_RX interface in CPUS domain
- Full physical layer implementation
- Supports NEC format infra data
- Supports CIR for remote control
- 64x8 bits FIFO for data buffer
- Sample clock up to 1 MHz

#### 1.3.10.2 CIR Transmitter (CIR\_TX)

- One CIR\_TX interface in CPUX domain
- Full physical layer implementation
- Arbitrary wave generator
- Configurable carrier frequency
- Handshake mode and waiting mode of DMA
- 128 bytes FIFO for data buffer
- Supports Interrupts and DMA

#### 1.3.10.3 GMAC

- One GMAC interface (GMAC) for connecting external Ethernet PHY
- 10/100/1000 Mbit/s Ethernet port with RGMII and RMII interfaces
- Compliant with IEEE 802.3-2002 standard
- Supports both full-duplex and half-duplex operations
- Programmable frame length to support Standard or Jumbo Ethernet frames with sizes up to 16 KB
- Supports a variety of flexible address filtering modes
- Separate 32-bit status returned for transmission and reception packets
- Optimization for packet-oriented DMA transfers with frame delimiters

- Supports linked-list descriptor list structure
- Descriptor architecture, allowing large blocks of data transfer with minimum CPU intervention; each descriptor can transfer up to 4 KB of data
- Comprehensive status reporting for normal operation and transfers with errors
- 2 KB TXFIFO for transmission packets and 8 KB RXFIFO for reception packets
- Programmable interrupt options for different operational conditions
- Provides the management data input/output (MDIO) interface for PHY device configuration and management with configurable clock frequencies

#### 1.3.10.4 General Purpose ADC (GPADC)

- 4-ch successive approximation register (SAR) analog-to-digital converter (ADC)
- 64 FIFO depth of data register
- 12-bit sampling resolution and 10-bit precision
- Power reference voltage: AVCC, analog input voltage range: 0 to AVCC
- Maximum sampling frequency up to 1 MHz
- Supports three operation modes: single conversion mode, continuous conversion mode, burst conversion mode

#### 1.3.10.5 LEDC

- Configurable LED output high/low level width
- Configurable LED reset time
- LEDC data supports DMA configuration mode and CPU configuration mode
- Maximum 1024 LEDs serial connect
- Configurable interval time between data packets and frame data
- Configurable RGB display mode

#### 1.3.10.6 Low Rate ADC (LRADC)

- 2-ch LRADC input
- 6-bit resolution
- Sampling rate up to 2 KHz
- Supports hold key and general key
- Supports normal, continue and single work mode
- Power supply voltage: 1.8V, power reference voltage: 1.35V

### 1.3.10.7 USB2.0 DRD

- One USB2.0 DRD (USB0), with integrated USB 2.0 analog PHY
- Complies with USB2.0 Specification
- USB Host that supports the following:
  - Compatible with Enhanced Host Controller Interface (EHCI) Specification, Version 1.0
  - Compatible with Open Host Controller Interface (OHCI) Specification, Version 1.0a
  - Supports High-Speed (HS, 480 Mbit/s), Full-Speed (FS, 12 Mbit/s), and Low-Speed (LS, 1.5 Mbit/s)
  - Supports only 1 USB Root port shared between EHCI and OHCI
- USB Device that supports the following:
  - Supports High-Speed (HS, 480 Mbit/s), Full-Speed (FS, 12 Mbit/s)
  - Supports bi-directional endpoint0 (EP0) for Control transfer
  - Up to 10 user-configurable endpoints (EP1 IN/OUT, EP2 IN/OUT, EP3 IN/OUT, EP4 IN/OUT, EP5 IN/OUT) for Bulk transfer, Isochronous transfer and Interrupt transfer
  - Up to (8 KB + 64 Bytes) FIFO for all EPs (including EP0)
  - Supports interface to an external Normal DMA controller for every EP
- Supports an internal DMA controller for data transfer with memory
- Supports High-Bandwidth Isochronous & Interrupt transfers
- Automated splitting/combining of packets for Bulk transfers
- Supports point-to-point and point-to-multipoint transfer in both Host and Peripheral modes
- Includes automatic PING capabilities
- Soft connect/disconnect function
- Performs all transaction scheduling in hardware
- Power optimization and power management capabilities
- Device and host controller share an 8K SRAM and a physical PHY

### 1.3.10.8 USB2.0 HOST

- One USB 2.0 HOST (USB1), with integrated USB 2.0 analog PHY
- Industry-standard AMBA High-Performance Bus (AHB), fully compliant with the AMBA Specification, Revision 2.0
- 32-bit Little Endian AMBA AHB Slave Bus for Register Access
- 32-bit Little Endian AMBA AHB Master Bus for Memory Access
- An internal DMA Controller for data transfer with memory

- Compatible with Enhanced Host Controller Interface (EHCI) Specification, Version 1.0
- Compatible with Open Host Controller Interface (OHCI) Specification, Version 1.0a
- Supports High-Speed (HS, 480 Mbit/s), Full-Speed (FS, 12 Mbit/s) and Low-Speed (LS, 1.5 Mbit/s) Device
- Supports the UTMI+ Level 3 interface and 8-bit bidirectional data buses
- Supports only 1 USB Root port shared between EHCI and OHCI

### 1.3.10.9 PCIe2.1&USB3.1 System

PCIe2.1&USB3.1 system contains 1 PCIe2.1&USB3.1 combo PHY, 1 PCIe2.1 controller and 1 USB3.1 GEN1 DRD controller.

#### PCIe2.1

- Complies with PCI Express Base 2.1 Specification
- Only supports Root Complex (RC) mode
- Embedded PCI Express PHY, supports x1 Gen2 (5.0 Gbit/s) lane
- Maximum payload size: 1024 bytes
- Supports 8 Inbound windows and 8 Outbound window
- 4 writing channels and 4 reading channels for embedded DMA
- Supports Message Signaled Interrupts (MSI)

#### USB3.1 DRD



USB2.0 PHY and USB3.1 PHY share the same controller. They cannot be used simultaneously.

- Compliant with USB3.1 GEN1 Specification
- One USB 2.0 UTMI+ PHY (USB2)
- One USB3.1 PIPE PHY (USB3)
- USB3.1 DRD Device mode supports the following:
  - Super-Speed (SS, 5 Gbit/s) for USB3.1 PHY
  - High-Speed (HS, 480 Mbit/s) and Full-Speed (FS, 12-Mbit/s) for USB2.0 PHY
- USB3.1 DRD HOST mode supports the following:
  - Super-Speed (SS, 5 Gbit/s) for USB3.1 PHY
  - High-Speed (HS, 480 Mbit/s), Full-Speed (FS, 12 Mbit/s) and Low-Speed (LS, 1.5 Mbit/s) for USB2.0 PHY

- Supports Device or Host operation at a time
- AXI interface for DMA operation
- Reading and writing access to Control and Status Registers (CSRs) through AHB Slave interface
- Up to 10 Endpoints, including bi-directional control Endpoint 0 in Device mode:
  - 5 IN Endpoints: User EP1 IN, EP2 IN, EP3 IN, EP4 IN, Control EP0 IN
  - 5 OUT Endpoints: User EP1 OUT, EP2 OUT, EP3 OUT, EP4 OUT, Control EP0 OUT
- Simultaneous IN and OUT transfer in Super-Speed mode
- Dual-port interfaces for TX data buffering, RX data prefetching, descriptor caching, and register caching
- Three RAMs: Rx data FIFO RAM, TX data FIFO RAM, and descriptor/register Cache RAM
- Hardware handles all data transfer
- Implements both static and dynamic power reduction techniques at multiple levels

#### 1.3.10.10 PWM

- Up to 30 PWM channels and 4 PWM controllers: PWM [19:0] in CPUX domain, S-PWM [9:0] in CPUS domain
  - PWM [15:0] for PWMCTRL0 controller
  - PWM [19:16] for PWMCTRL1 controller
  - S-PWM [1:0] for S\_PWMCTRL controller
  - S-PWM [9:2] for MCU\_PWMCTRL controller
- Maximum 16 independent PWM channels for PWM controller
  - Supports PWM continuous mode output
  - Supports PWM pulse mode output, and the pulse number is configurable
  - Output frequency range:
    - 0 to 24 MHz (when the clock source is DCXO24M)
    - 0 to 100 MHz (when the clock source is APB1 clock)
  - Various duty-cycle: 0% to 100%
  - Minimum resolution: 1/65536
- Maximum 8 complementary pairs output
  - The pairing methods for each PWM controller are as follows. The components are internal PWM channels:
    - Maximum 8 pairs for PWMCTRL0:

PWM0 + PWM1, PWM2 + PWM3, PWM4 + PWM5, PWM6 + PWM7, PWM8 + PWM9,  
PWM10 + PWM11, PWM12 + PWM13, PWM14 + PWM15

- Maximum 2 pairs for PWMCTRL1:  
PWM0+PWM1, PWM2+PWM3
- Maximum 1 pair for S\_PWMCTRL:  
PWM0+PWM1
- Maximum 4 pairs for MCU\_PWMCTRL:  
PWM0+PWM1, PWM2+PWM3, PWM4+PWM5, PWM6+PWM7
  - Supports dead-zone generator, and the dead-zone time is configurable
- Maximum 4 group of PWM channel output for controlling stepping motors
  - Supports any plural channels to form a group, and output the same duty-cycle pulse
  - In group mode, the relative phase of the output waveform for each channel is configurable
- Maximum 16 channels capture input
  - Supports rising edge detection and falling edge detection for input waveform pulse
  - Supports pulse-width measurement for input waveform pulse

### 1.3.10.11 SPI and SPI\_DBI

- Up to 4 SPI controllers
  - SPI0, SPI1, and SPI2 in CPUX Domain
  - S-SPI0 in CPUS Domain
- The SPI0, SPI2, and S-SPI0 support SPI mode; The SPI1 supports SPI mode and display bus interface (DBI) mode

#### SPI mode

- Multiple SPI modes:
  - Master mode and slave mode for standard SPI
  - Master mode for Dual-Output/Dual-Input SPI and Dual I/O SPI
  - Master mode for Quad-Output/Quad-Input SPI
  - Master mode for 3-wire SPI, with programmable serial data frame length of 1 bit to 32 bits
- Maximum clock frequency: 100MHz
- TX/RX DMA slave interface
- 8-bit wide by 64-entry FIFO for both transmitting and receiving data

- Supports mode0, mode1, mode2, and mode3
- Polarity and phase of the Chip Select (SPI\_SS) and SPI Clock (SPI\_SCLK) are configurable

#### DBI mode

- DBI Type C 3 Line/4 Line Interface Mode
- 2 Data Lane Interface Mode
- RGB111/444/565/666/888 video format
- Maximum resolution of RGB666 240 x 320@30Hz with single data lane
- Maximum resolution of RGB888 240 x 320@60Hz or 320 x 480@30Hz with dual data lane
- Tearing effect
- Software flexible control video frame rate

#### 1.3.10.12 SPI Flash Controller (SPIFC)

- Supports multiple SPI modes
  - Standard SPI
  - Dual-Input/Dual-Output SPI and Dual-I/O SPI
  - Quad-Input/Quad-Output SPI, Quad-I/O SPI, and QPI
  - Octal-Input/Octal-Output SPI, Octal-I/O SPI, and OPI
  - 3-wire SPI with programmable serial data frame length of 1 bit to 32 bits
- Supports STR mode and DTR mode, and DTR mode supports DQS signal
- High Speed Clock Frequency
  - 150MHz for STR Mode
  - 100MHz for DTR Mode
- Software Write Protection
  - Write protection for all/portion of memory via software
  - Top/Bottom Block protection
- Programmable delay between transactions
- Supports Mode0, Mode1, Mode2 and Mode3
- Supports control signal configuration
  - Up to four chip selects to support multiple peripherals
  - Polarity and phase of the Chip Select (SPI\_SS) and SPI Clock (SPI\_SCLK) are configurable

### 1.3.10.13 Two Wire Interface (TWI)

- Up to 9 TWI controllers
  - 6 TWI controllers in CPUX domain: TWI0, TWI1, TWI2, TWI3, TWI4, and TWI5
  - 3 TWI controllers in CPUS domain: S\_TWI0, S\_TWI1, and S\_TWI2
- Compliant with I2C bus standard
- 7-bit and 10-bit device addressing modes
- Standard mode (up to 100 Kbit/s) and fast mode (up to 400 Kbit/s)
- Supports general call and start byte
- Master mode supports the following:
  - Bus arbitration in the case of multiple master devices
  - Clock synchronization and bit and byte waiting
  - Packet transmission and DMA
- Slave mode supports Interrupt on address detection

### 1.3.10.14 UART

- Up to 10 UART controllers
  - 8 UART controllers in CPUX domain: UART0, UART1, UART2, UART3, UART4, UART5, UART6, and UART7
  - 2 UART controllers in CPUS domain: S\_UART0 and S\_UART1
- Compatible with industry-standard 16450/16550 UARTs
- Two separate FIFOs: one is RX FIFO, and the other is TX FIFO
  - Each of them is 64 bytes for UART0, S\_UART0, and S\_UART1
  - Each of them is 128 bytes for UART1, UART2, UART3, UART4, UART5, UART6, and UART7
- The working reference clock is from the APB bus clock
  - Speed up to 10 Mbit/s with 160 MHz APB clock (excluding S\_UART0 and S\_UART1)
  - Speed up to 5 Mbit/s with 80 MHz APB clock (excluding S\_UART0 and S\_UART1)
  - Speed up to 3.75 Mbit/s with 60 MHz APB clock (excluding S\_UART0 and S\_UART1)
  - Speed up to 1.5 Mbit/s with 24 MHz APB clock
- 5 to 8 data bits for RS-232 format, or 9 bits RS-485 format
- 1, 1.5 or 2 stop bits
- Programmable parity (even, odd, or no parity)
- Supports TX/RX DMA slave controller interface

- 
- Supports software/hardware flow control
  - Supports IrDA-compatible slow infrared (SIR) format
  - Supports auto-flow by using CTS & RTS (excluding UART0, S\_UART0, and S\_UART1)

### 1.3.11 Package

FCCSP 522 balls, 15 mm x 15 mm body size, 0.5 mm ball pitch, 0.3 mm ball size



## 1.4 Block Diagram

The following figure shows the system block diagram of the A523.

**Figure 1-1 A523 System Block Diagram**



The following figure shows the medium- and high-end tablet solution of the A523.

**Figure 1-2 Medium and High-End Tablet Solution**



# Contents

|       |                                            |     |
|-------|--------------------------------------------|-----|
| 2     | System .....                               | 40  |
| 2.1   | Memory Mapping .....                       | 40  |
| 2.2   | ARM Cortex™-A55 System(CPUX) .....         | 45  |
| 2.2.1 | Overview .....                             | 45  |
| 2.2.2 | Block diagram .....                        | 46  |
| 2.2.3 | Functional Descriptions .....              | 47  |
| 2.2.4 | Programming Guidelines .....               | 49  |
| 2.2.5 | Register list .....                        | 50  |
| 2.2.6 | CPU_SUBSYS_CTRL Register Description ..... | 53  |
| 2.2.7 | TIMESTAMP_STA Register Description .....   | 62  |
| 2.2.8 | TIMESTAMP_CTRL Register Description .....  | 66  |
| 2.2.9 | CPU_PLL_CFG Register Description .....     | 72  |
| 2.3   | RISC-V System (RISCV) .....                | 89  |
| 2.3.1 | Overview .....                             | 89  |
| 2.3.2 | Block Diagram .....                        | 89  |
| 2.3.3 | Register List .....                        | 90  |
| 2.3.4 | Register Description .....                 | 90  |
| 2.4   | BROM System .....                          | 93  |
| 2.4.1 | Overview .....                             | 93  |
| 2.4.2 | Functional Description .....               | 93  |
| 2.5   | Clock Controller Unit (CCU) .....          | 101 |
| 2.5.1 | Overview .....                             | 101 |
| 2.5.2 | Block Diagram .....                        | 102 |
| 2.5.3 | Functional Description .....               | 102 |
| 2.5.4 | Programming Guidelines .....               | 104 |
| 2.5.5 | Register List .....                        | 108 |
| 2.5.6 | Register Description .....                 | 112 |
| 2.6   | DMA Controller (DMAC) .....                | 210 |
| 2.6.1 | Overview .....                             | 210 |
| 2.6.2 | Block Diagram .....                        | 211 |

|        |                                              |     |
|--------|----------------------------------------------|-----|
| 2.6.3  | Functional Description .....                 | 212 |
| 2.6.4  | Programming Guidelines .....                 | 221 |
| 2.6.5  | Register List .....                          | 225 |
| 2.6.6  | Register Description .....                   | 226 |
| 2.7    | Generic Interrupt Controller (GIC) .....     | 254 |
| 2.7.1  | Overview .....                               | 254 |
| 2.7.2  | Functional Description .....                 | 255 |
| 2.7.3  | Register List .....                          | 263 |
| 2.7.4  | Register Description .....                   | 277 |
| 2.8    | Core-Local Interrupt Controller (CLIC) ..... | 278 |
| 2.8.1  | Overview .....                               | 278 |
| 2.8.2  | Functional Description .....                 | 278 |
| 2.8.3  | Register List .....                          | 284 |
| 2.8.4  | CLIC Register description .....              | 285 |
| 2.8.5  | S_INTC Register Description .....            | 287 |
| 2.9    | I/O Memory Management Unit (IOMMU) .....     | 289 |
| 2.9.1  | Overview .....                               | 289 |
| 2.9.2  | Block Diagram .....                          | 289 |
| 2.9.3  | Functional Descriptions .....                | 290 |
| 2.9.4  | Programming Guidelines .....                 | 298 |
| 2.9.5  | Register List .....                          | 299 |
| 2.9.6  | Register Description .....                   | 302 |
| 2.10   | Message Box (MSGBOX) .....                   | 339 |
| 2.10.1 | Overview .....                               | 339 |
| 2.10.2 | Block Diagram .....                          | 339 |
| 2.10.3 | Functional Description .....                 | 340 |
| 2.10.4 | Programming Guidelines .....                 | 341 |
| 2.10.5 | Register List .....                          | 342 |
| 2.10.6 | Register Description .....                   | 343 |
| 2.11   | Power Reset Clock Management (PRCM) .....    | 350 |
| 2.11.1 | Overview .....                               | 350 |
| 2.11.2 | Functional Description .....                 | 351 |
| 2.11.3 | Programming Guidelines .....                 | 353 |

|                                            |     |
|--------------------------------------------|-----|
| 2.11.4 Register List .....                 | 356 |
| 2.11.5 PRCM Register Description .....     | 359 |
| 2.11.6 MCU_PRCM Register Description ..... | 382 |
| 2.12 RTC .....                             | 406 |
| 2.12.1 Overview .....                      | 406 |
| 2.12.2 Block Diagram .....                 | 407 |
| 2.12.3 Functional Descriptions .....       | 407 |
| 2.12.4 Programming Guidelines .....        | 413 |
| 2.12.5 Register List .....                 | 414 |
| 2.12.6 Register Description .....          | 415 |
| 2.13 Spinlock .....                        | 429 |
| 2.13.1 Overview .....                      | 429 |
| 2.13.2 Block Diagram .....                 | 429 |
| 2.13.3 Functional Description .....        | 429 |
| 2.13.4 Programming Guidelines .....        | 431 |
| 2.13.5 Register List .....                 | 433 |
| 2.13.6 Register Description .....          | 434 |
| 2.14 Thermal Sensor Controller (THS) ..... | 437 |
| 2.14.1 Overview .....                      | 437 |
| 2.14.2 Block Diagram .....                 | 437 |
| 2.14.3 Functional Description .....        | 438 |
| 2.14.4 Programming Guidelines .....        | 440 |
| 2.14.5 Register List .....                 | 441 |
| 2.14.6 THS0 Register Description .....     | 443 |
| 2.14.7 THS1 Register Description .....     | 447 |
| 2.15 Timer .....                           | 455 |
| 2.15.1 Overview .....                      | 455 |
| 2.15.2 Block Diagram .....                 | 455 |
| 2.15.3 Functional Descriptions .....       | 456 |
| 2.15.4 Programming Guidelines .....        | 457 |
| 2.15.5 Register List .....                 | 458 |
| 2.15.6 Register Description .....          | 458 |
| 2.16 Watchdog Timer (WDT) .....            | 462 |

---

|                                      |     |
|--------------------------------------|-----|
| 2.16.1 Overview .....                | 462 |
| 2.16.2 Block Diagram .....           | 462 |
| 2.16.3 Functional Descriptions ..... | 462 |
| 2.16.4 Programming Guidelines .....  | 463 |
| 2.16.5 Register List .....           | 464 |
| 2.16.6 Register Description .....    | 465 |



# Figures

|                                                                                 |     |
|---------------------------------------------------------------------------------|-----|
| Figure 2-1 CPUX System Block Diagram .....                                      | 46  |
| Figure 2-2 RISC-V System Block Diagram .....                                    | 89  |
| Figure 2-3 Boot Process in Normal BROM Mode .....                               | 96  |
| Figure 2-4 Authentication Process in Secure BROM Mode .....                     | 97  |
| Figure 2-5 Mandatory Upgrade Process .....                                      | 98  |
| Figure 2-6 USB FEL Process .....                                                | 99  |
| Figure 2-7 CCU Block Diagram .....                                              | 102 |
| Figure 2-8 CCU Typical Application Diagram .....                                | 102 |
| Figure 2-9 PLL Distribution .....                                               | 103 |
| Figure 2-10 DMAC Block Diagram .....                                            | 211 |
| Figure 2-11 DMAC Typical Application Diagram .....                              | 212 |
| Figure 2-12 DMA Descriptor .....                                                | 215 |
| Figure 2-13 DMA Chain Transfer .....                                            | 217 |
| Figure 2-14 Workflow of the DMAC Handshake Mode .....                           | 220 |
| Figure 2-15 DMAC Transfer Process .....                                         | 222 |
| Figure 2-16 IOMMU Block Diagram .....                                           | 290 |
| Figure 2-17 Internal Switch Process .....                                       | 294 |
| Figure 2-18 VA-PA Switch Process .....                                          | 295 |
| Figure 2-19 Invalid TLB Address Range .....                                     | 296 |
| Figure 2-20 Level1 Page Table Format .....                                      | 297 |
| Figure 2-21 Level2 Page Table Format .....                                      | 298 |
| Figure 2-22 Message Box Block Diagram .....                                     | 339 |
| Figure 2-23 The Communication Process between CPUX_MSGBOX and CPUS_MSGBOX ..... | 342 |
| Figure 2-24 System Bus Tree of PRCM .....                                       | 351 |
| Figure 2-25 System Bus Tree of MCU_PRCM .....                                   | 352 |
| Figure 2-26 Bus Clock Tree .....                                                | 352 |
| Figure 2-27 PLL Distribution of PRCM .....                                      | 353 |
| Figure 2-28 PLL Distribution of MCU_PRCM .....                                  | 353 |
| Figure 2-29 RTC Block Diagram .....                                             | 407 |
| Figure 2-30 RTC Application Diagram .....                                       | 408 |

---

|                                                                   |     |
|-------------------------------------------------------------------|-----|
| Figure 2-31 RTC Clock Tree .....                                  | 409 |
| Figure 2-32 RTC Counter .....                                     | 410 |
| Figure 2-33 RTC 1 kHz Counter Step Structure .....                | 410 |
| Figure 2-34 Calibration Circuit.....                              | 411 |
| Figure 2-35 RC Waveform .....                                     | 411 |
| Figure 2-36 DCXO Timed Wakeup Waveform .....                      | 412 |
| Figure 2-37 Spinlock Block Diagram .....                          | 429 |
| Figure 2-38 Spinlock Typical Application Diagram .....            | 430 |
| Figure 2-39 Spinlock State Machine.....                           | 431 |
| Figure 2-40 CPUX and RISCV Taking/Freeing Spinlock0 Process ..... | 432 |
| Figure 2-41 THS0 Block Diagram .....                              | 437 |
| Figure 2-42 THS1 Block Diagram .....                              | 438 |
| Figure 2-43 Thermal Sensor Timing Requirement .....               | 438 |
| Figure 2-44 Thermal Sensor Controller Interrupt Source .....      | 439 |
| Figure 2-45 THS Initial Process .....                             | 440 |
| Figure 2-46 Block Diagram for the Timer .....                     | 455 |
| Figure 2-47 Timer Typical Application .....                       | 456 |
| Figure 2-48 Watchdog Block Diagram .....                          | 462 |
| Figure 2-49 Watchdog Application Diagram .....                    | 463 |

# Tables

|                                                                    |     |
|--------------------------------------------------------------------|-----|
| Table 2-1 CPUX DynamIQ Cluster Components .....                    | 47  |
| Table 2-2 CPUX Power domain .....                                  | 47  |
| Table 2-3 Clock Sources of CPUX Cores and DSU .....                | 48  |
| Table 2-4 Reset signal description of CPUX System .....            | 48  |
| Table 2-5 BOOT_MODE Setting .....                                  | 93  |
| Table 2-6 GPADC Boot Select Setting .....                          | 94  |
| Table 2-7 Groups of eFuse_Boot_Select .....                        | 94  |
| Table 2-8 eFuse Boot Select Setting .....                          | 95  |
| Table 2-9 Fast Boot Select Setting .....                           | 100 |
| Table 2-10 PLL Features .....                                      | 103 |
| Table 2-11 DMAC Sub-blocks .....                                   | 211 |
| Table 2-12 DMA DRQ Type .....                                      | 213 |
| Table 2-13 DMA DRQ Type of MCU_DMAC .....                          | 214 |
| Table 2-14 Source/Destination Address Distribution .....           | 216 |
| Table 2-15 Interrupt Source in CPUX Domain .....                   | 255 |
| Table 2-16 Interrupt Sources .....                                 | 278 |
| Table 2-17 Correspondence Relation between Master and Module ..... | 290 |
| Table 2-18 PLL Features .....                                      | 353 |
| Table 2-19 RTC External Signals .....                              | 407 |
| Table 2-20 RTC Counter Changing Range .....                        | 410 |
| Table 2-21 THS Information in the SID .....                        | 440 |

## 2 System

### 2.1 Memory Mapping

| Module                 | Address                   | Size(Bytes)                                          |
|------------------------|---------------------------|------------------------------------------------------|
| <b>BROM &amp; SRAM</b> |                           |                                                      |
| S_BROM                 | 0x0000 0000---0x0000 AFFF | 44 KB                                                |
| M_BROM                 | 0x0001 0000---0x0001 8FFF | 36 KB                                                |
| MCU0 SRAM              | 0x0002 0000---0x0003 FFFF | 128 KB<br>The local SRAM is switched to system boot. |
| SRAM A2                | 0x0004 0000---0x0006 3FFF | 16 KB+128 KB                                         |
| <b>GPU_SYS</b>         |                           |                                                      |
| GPU                    | 0x0180 0000---0x0183 FFFF | 256 KB                                               |
| <b>VE_SYS</b>          |                           |                                                      |
| VE                     | 0x01C0 E000---0x01C0 EFFF | 4 KB                                                 |
| <b>SP0</b>             |                           |                                                      |
| GPIO                   | 0x0200 0000---0x0200 07FF | 2 KB                                                 |
| SPC                    | 0x0200 0800---0x0200 0BFF | 1 KB                                                 |
| PWMCTRL0               | 0x0200 0C00---0x0200 0FFF | 1 KB                                                 |
| CCU                    | 0x0200 1000---0x0200 1FFF | 4 KB                                                 |
| CIR_TX                 | 0x0200 3000---0x0200 33FF | 1 KB                                                 |
| CIR_RX                 | 0x0200 5000---0x0200 53FF | 1 KB                                                 |
| LEDC                   | 0x0200 8000---0x0200 83FF | 1 KB                                                 |
| GPADC                  | 0x0200 9000---0x0200 93FF | 1 KB                                                 |
| THS1                   | 0x0200 9400---0x0200 97FF | 1 KB                                                 |
| LRADC                  | 0x0200 9800---0x0200 9BFF | 1 KB                                                 |
| THS0                   | 0x0200 A000---0x0200 A3FF | 1 KB                                                 |
| IOMMU                  | 0x0201 0000---0x0201 FFFF | 64 KB                                                |
| NSI                    | 0x0202 0000---0x0202 FFFF | 64 KB                                                |
| CPUX_WDT               | 0x0205 0000---0x0205 0FFF | 4 KB                                                 |
| PWMCTRL1               | 0x0205 1000---0x0205 13FF | 1 KB                                                 |
| NSI_CPU                | 0x0207 1000---0x0207 13FF | 1 KB                                                 |
| <b>SP1</b>             |                           |                                                      |
| UART0                  | 0x0250 0000---0x0250 03FF | 1 KB                                                 |
| UART1                  | 0x0250 0400---0x0250 07FF | 1 KB                                                 |
| UART2                  | 0x0250 0800---0x0250 0BFF | 1 KB                                                 |
| UART3                  | 0x0250 0C00---0x0250 0FFF | 1 KB                                                 |

| Module           | Address                   | Size(Bytes) |
|------------------|---------------------------|-------------|
| UART4            | 0x0250 1000---0x0250 13FF | 1 KB        |
| UART5            | 0x0250 1400---0x0250 17FF | 1 KB        |
| UART6            | 0x0250 1800---0x0250 1BFF | 1 KB        |
| UART7            | 0x0250 1C00---0x0250 1FFF | 1 KB        |
| TWI0             | 0x0250 2000---0x0250 23FF | 1 KB        |
| TWI1             | 0x0250 2400---0x0250 27FF | 1 KB        |
| TWI2             | 0x0250 2800---0x0250 2BFF | 1 KB        |
| TWI3             | 0x0250 2C00---0x0250 2FFF | 1 KB        |
| TWI4             | 0x0250 3000---0x0250 33FF | 1 KB        |
| TWI5             | 0x0250 3400---0x0250 37FF | 1 KB        |
| <b>SH0</b>       |                           |             |
| SYSCTRL          | 0x0300 0000---0x0300 0FFF | 4 KB        |
| CPUX_TIMER       | 0x0300 8000---0x0300 83FF | 1 KB        |
| DMAC             | 0x0300 2000---0x0300 2FFF | 4 KB        |
| CPUX_MSGBOX      | 0x0300 3000---0x0300 3FFF | 4 KB        |
| SPINLOCK         | 0x0300 5000---0x0300 5FFF | 4 KB        |
| SID              | 0x0300 6000---0x0300 6FFF | 4 KB        |
| CE_NS            | 0x0304 0000---0x0304 07FF | 2 KB        |
| CE_S             | 0x0304 0800---0x0304 0FFF | 2 KB        |
| MEMC             | 0x0310 2000---0x0330 1FFF | 2 M         |
| MEMC_SMC         | 0x0311 0000---0x0311 FFFF | 64 KB       |
| MEMC_COMMON      | 0x0312 0000---0x0312 FFFF | 64 KB       |
| MEMC_DDRC        | 0x0313 0000---0x0313 FFFF | 64 KB       |
| MEMC_PHY         | 0x0314 0000---0x0314 FFFF | 64 KB       |
| GIC              | 0x0340 0000---0x034E FFFF | 15*64 KB    |
| <b>SH2</b>       |                           |             |
| NDFC             | 0x0401 1000---0x0401 1FFF | 4 KB        |
| SMHC0            | 0x0402 0000---0x0402 0FFF | 4 KB        |
| SMHC1            | 0x0402 1000---0x0402 1FFF | 4 KB        |
| SMHC2            | 0x0402 2000---0x0402 2FFF | 4 KB        |
| SPI0             | 0x0402 5000---0x0402 5FFF | 4 KB        |
| SPI1             | 0x0402 6000---0x0402 6FFF | 4 KB        |
| SPI2             | 0x0402 7000---0x0402 7FFF | 4 KB        |
| USB0             | 0x0410 0000---0x041F FFFF | 1 MB        |
| USB1             | 0x0420 0000---0x042F FFFF | 1 MB        |
| GMAC             | 0x0450 0000---0x0450 FFFF | 64 KB       |
| SPIFC            | 0x047F 0000---0x047F 0FFF | 4 KB        |
| PCIE             | 0x0480 0000---0x04CF FFFF | 5 MB        |
| USB3             | 0x04D0 0000---0x04EF FFFF | 2 MB        |
| PCIE_USB3_TOP_AP | 0x04F0 0000---0x04F7 FFFF | 512 KB      |

| Module                 | Address                   | Size(Bytes) |
|------------------------|---------------------------|-------------|
| P                      |                           |             |
| <b>DE_SYS</b>          |                           |             |
| DE                     | 0x0500 0000---0x053F FFFF | 4 MB        |
| DI                     | 0x0540 0000---0x0543 FFFF | 256 KB      |
| G2D                    | 0x0544 0000---0x0547 FFFF | 256 KB      |
| <b>VIDEO0_OUT_SYS</b>  |                           |             |
| DISPLAY0_TOP           | 0x0550 0000---0x0550 0FFF | 4 KB        |
| TCON_LCD0              | 0x0550 1000---0x0550 1FFF | 4 KB        |
| TCON_LCD1              | 0x0550 2000---0x0550 2FFF | 4 KB        |
| TCON_TV1               | 0x0550 4000---0x0550 4FFF | 4 KB        |
| COMBOPHY_DSI0          | 0x0550 6000---0x0550 7FFF | 8 KB        |
| COMBOPHY_DSI1          | 0x0550 8000---0x0550 9FFF | 8 KB        |
| EDP                    | 0x0572 0000---0x0572 3FFF | 16 KB       |
| <b>VIDEO_IN_SYS</b>    |                           |             |
| CSI                    | 0x0580 0000---0x058F FFFF | 1 MB        |
| ISP                    | 0x0590 0000---0x05CF FFFF | 4 MB        |
| <b>APBS0</b>           |                           |             |
| S_PPU1                 | 0x0700 1400---0x0700 17FF | 1 KB        |
| S_SPC                  | 0x0700 2000---0x0700 23FF | 1 KB        |
| PRCM                   | 0x0701 0000---0x0701 FFFF | 64 KB       |
| CPUS_WDT               | 0x0702 0400---0x0702 07FF | 1 KB        |
| S_TWD                  | 0x0702 0800---0x0702 0BFF | 1 KB        |
| S_PWMCTRL              | 0x0702 0C00---0x0702 0FFF | 1 KB        |
| S_INTC                 | 0x0702 1000---0x0702 13FF | 1 KB        |
| S_GPIO                 | 0x0702 2000---0x0702 27FF | 2 KB        |
| CPUS_CFG               | 0x0703 1000---0x0703 1FFF | 4 KB        |
| S_CIRRX                | 0x0704 0000---0x0704 03FF | 1 KB        |
| PCK600_CPU             | 0x0705 0000---0x0705 FFFF | 64 KB       |
| PCK600_QCHANNEL(S_PPU) | 0x0706 0000---0x0706 7FFF | 32 KB       |
| <b>APBS1</b>           |                           |             |
| S_UART0                | 0x0708 0000---0x0708 03FF | 1 KB        |
| S_UART1                | 0x0708 0400---0x0708 07FF | 1 KB        |
| S_TWI0                 | 0x0708 1400---0x0708 17FF | 1 KB        |
| S_TWI1                 | 0x0708 1800---0x0708 1BFF | 1 KB        |
| S_TWI2                 | 0x0708 1C00---0x0708 1FFF | 1 KB        |
| <b>AHBS</b>            |                           |             |
| RTC                    | 0x0709 0000---0x0709 03FF | 1 KB        |
| CPUS_TIMER             | 0x0709 0400---0x0709 07FF | 1 KB        |
| S_SPI0                 | 0x0709 2000---0x0709 2FFF | 4 KB        |
| S_SPINLOCK             | 0x0709 3000---0x0709 3FFF | 4 KB        |

| Module              | Address                   | Size(Bytes)                                             |
|---------------------|---------------------------|---------------------------------------------------------|
| CPUS_MSGBOX         | 0x0709 4000---0x0709 4FFF | 4 KB                                                    |
| <b>MCU_APB0</b>     |                           |                                                         |
| MCU_PRCM            | 0x0710 2000---0x0710 2FFF | 4 KB                                                    |
| MCU_PWMCTRL         | 0x0710 3000---0x0710 33FF | 1 KB                                                    |
| AUDIO CODEC         | 0x0711 0000---0x0711 0FFF | 4 KB                                                    |
| DMIC                | 0x0711 1000---0x0711 13FF | 1 KB                                                    |
| I2S0                | 0x0711 2000---0x0711 2FFF | 4 KB                                                    |
| I2S1                | 0x0711 3000---0x0711 3FFF | 4 KB                                                    |
| I2S2                | 0x0711 4000---0x0711 4FFF | 4 KB                                                    |
| I2S3                | 0x0711 5000---0x0711 5FFF | 4 KB                                                    |
| OWA                 | 0x0711 6000---0x0711 63FF | 1 KB                                                    |
| <b>MCU_AHB</b>      |                           |                                                         |
| MCU_DMAC            | 0x0712 1000---0x0712 1FFF | 4 KB                                                    |
| MCU_TIMER           | 0x0712 3000---0x0712 33FF | 1 KB                                                    |
| <b>RISCV_SYS</b>    |                           |                                                         |
| RISCV_CFG           | 0x0713 0000---0x0713 0FFF | 4 KB                                                    |
| RISCV_WDT           | 0x0713 2000---0x0713 2FFF | 4 KB                                                    |
| RISCV_LCNT          | 0x0713 4000---0x0713 4FFF | 4 KB                                                    |
| RISCV_MSGBOX        | 0x0713 6000---0x0713 6FFF | 4 KB                                                    |
| <b>MCU_SRAM</b>     |                           |                                                         |
| SRAMA3_0            | 0x0728 0000---0x072B FFFF | 256 KB (SRAMA3_0 can not be used cross 256 KB boundary) |
| SRAMA3_1            | 0x072C 0000---0x072F FFFF | 256 KB (SRAMA3_1 can not be used cross 256 KB boundary) |
| SRAMA3_2            | 0x0730 0000---0x0737 FFFF | 512 KB                                                  |
| <b>CPUX Related</b> |                           |                                                         |
| CPU_SUBSYS_CTRL     | 0x0800 0000---0x0800 0FFF | 4 KB                                                    |
| TIMESTAMP_STA       | 0x0801 0000---0x0801 0FFF | 4 KB                                                    |
| TIMESTAMP_CTRL      | 0x0802 0000---0x0802 0FFF | 4 KB                                                    |
| APB_ROM1            | 0x0880 1000---0x0880 1FFF | 4 KB                                                    |
| CTI                 | 0x0880 3000---0x0880 3FFF | 4 KB                                                    |
| CS_TS_CTRL          | 0x0880 5000---0x0880 5FFF | 4 KB                                                    |
| CS_TS_READ          | 0x0880 7000---0x0880 7FFF | 4 KB                                                    |
| TPIU                | 0x0880 9000---0x0880 9FFF | 4 KB                                                    |
| ETB                 | 0x0880 B000---0x0880 BFFF | 4 KB                                                    |
| APB_ROM2            | 0x0881 1000---0x0881 1FFF | 4 KB                                                    |
| ATB_FUNNEL          | 0x0881 3000---0x0881 3FFF | 4 KB                                                    |
| CLUSTER_CFG         | 0x0881 5000---0x0881 5FFF | 4 KB                                                    |
| CPU_PLL_CFG         | 0x0881 7000---0x0881 7FFF | 4 KB                                                    |
| CLUSTER_DBUG        | 0x0980 0000---0x09BF FFFF | 4 MB                                                    |

| Module                                    | Address                    | Size(Bytes)                                                                 |
|-------------------------------------------|----------------------------|-----------------------------------------------------------------------------|
| <b>PCIE</b>                               |                            |                                                                             |
| PCIE_SLV                                  | 0x2000 0000---0x2FFF FFFF  | 256 MB                                                                      |
| <b>RISCV Related (Only RISC-V access)</b> |                            |                                                                             |
| RISCV_CLINT                               | 0xE000 0000---0xE000 FFFF  | 64 KB                                                                       |
| RISCV_CLIC                                | 0xE080 0000---0xE080 4FFF  | 20 KB                                                                       |
| RISCV_SYSMAP                              | 0xFFFF F000---0xFFFF FFFF  | 4 KB                                                                        |
| <b>DRAM Space</b>                         |                            |                                                                             |
| DRAM SPACE                                | 0x4000 0000---0x13FFF FFFF | 4 GB<br>RISC-V core accesses the DRAM address:<br>0x4004 0000---0x7FFF FFFF |



## 2.2 ARM Cortex™-A55 System(CPUX)

### 2.2.1 Overview

A523 CPU architecture adopts DynamIQ technology. The CPUX system includes DynamIQ Shared Unit (DSU), DynamIQ cluster, GIC600 distributor, coresight subsystem, and timestamp module. The features of the CPUX cores and DSU in DynamIQ cluster are as follows.

#### CPUX Cores

- Two sets of ARM Cortex™-A55 cores in a DynamIQ big. LITTLE configuration
- Memory subsystem features
  - 32 KB L1 I-cache and D-cache
  - Optional 64KB L2 cache for 'LITTLE' cores
  - Optional 128KB L2 cache for 'big' cores
  - Separate L1 instruction side memory subsystem with a Memory Management Unit (MMU)
- A64, A32, and T32 instruction sets running on ARMv8-A architecture ISA
- Both the AArch32 and AArch64 execution states at all Exception levels (EL0 to EL3).
- In-order pipeline with direct and indirect branch prediction.
- Optional Data Engine Unit implementing the advanced Single Instruction Multiple Data (SIMD) and floating-point architecture
- Optional Cryptography extensions
- Separate L1 instruction side memory system with a Memory Management Unit (MMU)
- ARM TrustZone® technology
- Generic Interrupt Controller (GIC) interface connecting an external distributor
- Generic Timers interface supporting 64-bit count input from an external system counter
- Reliability, Availability, and Serviceability (RAS) extension
- Debug and trace capabilities



#### NOTE

Cryptography extensions are available only when Data Engine unit is present.

#### DSU

DSU comprises the L3 cache, the Snoop Control Unit (SCU), internal interfaces to the cores, and external interfaces to the SoC.

- Memory subsystem features
  - 1024 KB L3 cache
  - Optional 16-way set-associative L3 cache, 64-byte cache line
  - L3 memory system can be clocked at a rate synchronous to the external system interconnect or at integer multiples.
  - L3 cache partial power down
  - Optional cache protection in the form of Error Correcting Code (ECC) on L3 cache RAM instances
  - 40-bit, 44-bit, and 48-bit physical addresses
- Main bus interface adopting AMBA 5 ACE protocol or AMBA 5 CHI protocol
- Optional 128-bit wide and I/O-coherent Accelerator Coherency Port (ACP)
- Optional 64-bit wide peripheral port
- ARMv8.2 debug logic
- Supports RAS

## 2.2.2 Block diagram

The following figure shows the block diagram of CPUX system.

Figure 2-1 CPUX System Block Diagram



The following table describes the components of A523 DynamIQ big.LITTLE cluster.

**Table 2-1 CPUX DynamIQ Cluster Components**

| Components                   | Description                                                                                                                                                                                                                                                                                        |
|------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CPU bridges                  | For communication between cores and DSU buffers.                                                                                                                                                                                                                                                   |
| SCU                          | The SCU maintains coherency and cache-to-cache transmission for all CPUX cores.                                                                                                                                                                                                                    |
| Debug and trace components   | Each core allows tracing supported by Embedded Trace Macrocell (ETM). The trigger events from CPUX cores are transmitted through debug APB master/slave interface.                                                                                                                                 |
| Clock and power management   | The cluster supports low power mode and is controlled by a low power control module outside the cluster power-down domain. DSU and each CPUX core has independent P-channels. They could control the power mode through P-channels.                                                                |
| L3 memory interfaces         | To access memory and peripherals.                                                                                                                                                                                                                                                                  |
| DSU system control registers | Include information related to CPUX core configuration, such as: <ul style="list-style-type: none"> <li>• Power management of the cluster</li> <li>• QOS and ID control of CHI bus</li> <li>• DSU hardware configuration information</li> <li>• L3 cache hit and miss count information</li> </ul> |

## 2.2.3 Functional Descriptions

### 2.2.3.1 Power Block System

#### Power Domain

The following table describes the power domain of the CPUX.

**Table 2-2 CPUX Power domain**

| Power Domain | Power Switch | Description                                                                                                          |
|--------------|--------------|----------------------------------------------------------------------------------------------------------------------|
| VDD-CPUB     | Yes          | Power source of Core4-Core7. It is controlled by the PPU for each core.                                              |
| VDD-CPUL     | Yes          | Power source of the cluster top and Core0-Core3. It is controlled by the PPU for the cluster top and each core.      |
| VDD-SYS      | No           | Power source of CPUX system excluding the cluster top and CPUX cores. It is the same power supply of the SoC system. |

#### Power Mode

CPUX cores support four power modes:

- Debug Recovery
- ON

- OFF (emulated)
- OFF

DSU supports the following power modes

- ON: SFONLY\_ON、1/4 ON、1/2 ON、3/4 ON、FULL ON
- Functional Retention: SFONLY\_FUNC\_RET, ¼FUNC\_RET, ½FUNC\_RET, ¾FUNC\_RET, FULL FUNC\_RET
- OFF and OFF\_EMU

### 2.2.3.2 CPU PLL Distribution and Clock Sources

The CPUX system contains three linear frequency modulation PLLs: CPU\_L\_PLL, CPU\_DSU\_PLL, and CPU\_B\_PLL. The following table shows the clock sources of CPUX cores and DSU.

**Table 2-3 Clock Sources of CPUX Cores and DSU**

| CPUX Cores  | Clock Sources     | Description                                                                                                                                                                                           |
|-------------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Core0-Core3 | CLK32K            | <ul style="list-style-type: none"> <li>Generally, CPU_L_PLL is the main clock source of Core0-Core3. For all clock sources of Core0-Core3, refer to <a href="#">CPUA_CLK_REG</a> register.</li> </ul> |
|             | CLK16M_RC         |                                                                                                                                                                                                       |
|             | HOSC              |                                                                                                                                                                                                       |
|             | PERI0_600M        |                                                                                                                                                                                                       |
|             | CPU_L_PLL         |                                                                                                                                                                                                       |
| Core4-Core7 | CLK32K            | <ul style="list-style-type: none"> <li>Generally, CPU_B_PLL is the main clock source of Core4-Core7. For all clock sources of Core4-Core7, refer to <a href="#">CPUB_CLK_REG</a> register.</li> </ul> |
|             | CLK16M_RC         |                                                                                                                                                                                                       |
|             | HOSC              |                                                                                                                                                                                                       |
|             | PERI0_600M        |                                                                                                                                                                                                       |
|             | CPU_PLL3CPU_B_PLL |                                                                                                                                                                                                       |
| DSU         | CLK32K            | <ul style="list-style-type: none"> <li>Generally, CPU_DSU_PLL is the main clock source of DSU. For all clock sources of DSU, refer to <a href="#">DSU_CLK_REG</a> register.</li> </ul>                |
|             | CLK16M_RC         |                                                                                                                                                                                                       |
|             | HOSC              |                                                                                                                                                                                                       |
|             | PERI0_600M        |                                                                                                                                                                                                       |
|             | PLL_PERI0(2X)     |                                                                                                                                                                                                       |
|             | CPU_DSU_PLL       |                                                                                                                                                                                                       |

### 2.2.3.3 CPUX Reset System

The following table shows the input reset signal of the whole CPUX system.

**Table 2-4 Reset signal description of CPUX System**

| Reset signal | Source | Description                                                                                                                |
|--------------|--------|----------------------------------------------------------------------------------------------------------------------------|
| DBGSYS_RST   | CCU    | For detailed information, please refer to the description of DBGSYS_RST in section 2.5.6.70 0x078C DBGSYS Bus Gating Reset |

| Reset signal | Source | Description                                                        |
|--------------|--------|--------------------------------------------------------------------|
|              |        | Register (Default Value: 0x0000_0000).                             |
| DSU_RSTN     | PPU    | Whether to reset is controlled by PPU according to the power mode. |
| CORE_RSTN    | PPU    | Whether to reset is controlled by PPU according to the power mode. |

## 2.2.4 Programming Guidelines

The following takes CPU\_L\_PLL as an example, CPU\_DSU\_PLL and CPU\_B\_PLL are the same.



It is not suggested to enable or disable the PLLs during usage. When the clock is not required, it is recommended to configure the PLL\_OUTPUT\_EN bit of PLL control register as 0.

### 2.2.4.1 Enabling the Linear Frequency Modulation PLLs

- Step 1 Write 1 to the PLL\_SSC\_CLK\_SEL bit (bit [29]) of [CPU\\_L\\_PLL\\_SSC\\_REG](#) register.
- Step 2 Configure the N, M, and P factors of the [CPU\\_L\\_PLL\\_CTRL\\_REG](#) register.
- Step 3 Write 1 to the PLL\_PLL\_EN bit (bit [31]) and the PLL\_LDO\_EN bit (bit [30]) of the [CPU\\_L\\_PLL\\_CTRL\\_REG](#) register.
- Step 4 Write 1 to the LOCK\_ENABLE bit (bit [29]) of the [CPU\\_L\\_PLL\\_CTRL\\_REG](#) register.
- Step 5 Write 1 to the PLL\_UPDATE bit (bit [26]) of the [CPU\\_L\\_PLL\\_CTRL\\_REG](#) register.
- Step 6 Wait for the value of the PLL\_UPDATE bit to change to 0.
- Step 7 Wait for the status of the Lock to change to 1.
- Step 8 Delay 10 ms.
- Step 9 Write 0 to the PLL\_SSC\_CLK\_SEL bit (bit [29]) of [CPU\\_L\\_PLL\\_SSC\\_REG](#) register.

### 2.2.4.2 Configuring the Frequency of Linear Frequency Modulation PLLs

- Step 1 Configure the PLL\_SSC\_STEP bit (bit [3:0]) of the [CPU\\_L\\_PLL\\_SSC\\_REG](#) register to select required frequency modulation slope.
- Step 2 Configure the PLL\_SSC bit (bit [28:12]) of the [CPU\\_L\\_PLL\\_SSC\\_REG](#) register to set the SSC amplitude.
- Step 3 Write 1 to the PLL\_SSC\_MODE bit (bit [31]) of the [CPU\\_L\\_PLL\\_SSC\\_REG](#) register to enable linear frequency modulation.

- Step 4** Write 1 to the PLL\_UPDATE bit (bit [26]) of the [CPU\\_L\\_PLL\\_CTRL\\_REG](#) register to update PLL configuration parameters.
- Step 5** Wait for the value of the PLL\_UPDATE bit to change to 0.
- Step 6** Configure the N factor of the [CPU\\_L\\_PLL\\_CTRL\\_REG](#) register.
- Step 7** Write 1 to the PLL\_UPDATE bit (bit [26]) of the [CPU\\_L\\_PLL\\_CTRL\\_REG](#) register to update PLL configuration parameters.
- Step 8** Wait for the value of the PLL\_UPDATE bit to change to 0.
- Step 9** Write 0 to the PLL\_SSC\_MODE bit (bit [31]) of the [CPU\\_L\\_PLL\\_SSC\\_REG](#) register to disable linear frequency modulation.
- Step 10** Write 1 to the PLL\_UPDATE bit (bit [26]) of the [CPU\\_L\\_PLL\\_CTRL\\_REG](#) register to update PLL configuration parameters.
- Step 11** Wait for the value of the PLL\_UPDATE bit to change to 0.

#### 2.2.4.3 Disabling the Linear Frequency Modulation PLLs

Follow the steps below to disable the PLL:

- Step 1** Write 0 to the PLL\_PLL\_EN bit (bit [31]) and the PLL\_LDO\_EN bit (bit [30]) of the [CPU\\_L\\_PLL\\_CTRL\\_REG](#) register.
- Step 2** Write 1 to the PLL\_UPDATE bit (bit [26]) of the [CPU\\_L\\_PLL\\_CTRL\\_REG](#) register.
- Step 3** Write 1 to the PLL\_SSC\_CLK\_SEL bit (bit [29]) of [CPU\\_L\\_PLL\\_SSC\\_REG](#) register.
- Step 4** Write 1 to the PLL\_UPDATE bit (bit [26]) of the [CPU\\_L\\_PLL\\_CTRL\\_REG](#) register.
- Step 5** Wait for the value of the PLL\_UPDATE bit to change to 0.
- Step 6** Write 0 to the PLL\_SSC\_CLK\_SEL bit (bit [29]) of [CPU\\_L\\_PLL\\_SSC\\_REG](#) register.

#### 2.2.5 Register list

| Module Name     | Base Address | Description                       |
|-----------------|--------------|-----------------------------------|
| CPU_SUBSYS_CTRL | 0x08000000   | CPU Subsystem Control (4KB)       |
| TIMESTAMP_STA   | 0x08010000   | Timestamp Status Registers (4KB)  |
| TIMESTAMP_CTRL  | 0x08020000   | Timestamp Control Registers (4KB) |
| CPU_PLL_CFG     | 0x08817000   | Cluster PLL configure (4KB)       |

##### 2.2.5.1 CPU\_SUBSYS\_CTRL Register List

| Register Name   | Offset | Description               |
|-----------------|--------|---------------------------|
| GENER_CTRL_REG0 | 0x0000 | General Control Register0 |

| Register Name     | Offset | Description                           |
|-------------------|--------|---------------------------------------|
| GIC_JTAG_RST_CTRL | 0x000C | GIC and JTAG reset control Register   |
| DBG_STATE         | 0x001C | Debug State Register                  |
| CPU0_CTRL_REG     | 0x0020 | CPU0 Control Register                 |
| CPU1_CTRL_REG     | 0x0024 | CPU1 Control Register                 |
| CPU2_CTRL_REG     | 0x0028 | CPU2 Control Register                 |
| CPU3_CTRL_REG     | 0x002C | CPU3 Control Register                 |
| CPU4_CTRL_REG     | 0x0030 | CPU4 Control Register                 |
| CPU5_CTRL_REG     | 0x0034 | CPU5 Control Register                 |
| CPU6_CTRL_REG     | 0x0038 | CPU6 Control Register                 |
| CPU7_CTRL_REG     | 0x003C | CPU7 Control Register                 |
| RVBARADDR0_L      | 0x0040 | Reset Vector Base Address Register0_L |
| RVBARADDR0_H      | 0x0044 | Reset Vector Base Address Register0_H |
| RVBARADDR1_L      | 0x0048 | Reset Vector Base Address Register1_L |
| RVBARADDR1_H      | 0x004C | Reset Vector Base Address Register1_H |
| RVBARADDR2_L      | 0x0050 | Reset Vector Base Address Register2_L |
| RVBARADDR2_H      | 0x0054 | Reset Vector Base Address Register2_H |
| RVBARADDR3_L      | 0x0058 | Reset Vector Base Address Register3_L |
| RVBARADDR3_H      | 0x005C | Reset Vector Base Address Register3_H |
| RVBARADDR4_L      | 0x0060 | Reset Vector Base Address Register4_L |
| RVBARADDR4_H      | 0x0064 | Reset Vector Base Address Register4_H |
| RVBARADDR5_L      | 0x0068 | Reset Vector Base Address Register5_L |
| RVBARADDR5_H      | 0x006C | Reset Vector Base Address Register5_H |
| RVBARADDR6_L      | 0x0070 | Reset Vector Base Address Register6_L |
| RVBARADDR6_H      | 0x0074 | Reset Vector Base Address Register6_H |
| RVBARADDR7_L      | 0x0078 | Reset Vector Base Address Register7_L |
| RVBARADDR7_H      | 0x007C | Reset Vector Base Address Register7_H |
| PLL_CTRL_REG0     | 0x0140 | PLL control register 0                |
| PLL_CTRL_REG1     | 0x0144 | PLL control register 1                |

### 2.2.5.2 TIMESTAMP\_STA Register List

| Register Name | Offset | Description                          |
|---------------|--------|--------------------------------------|
| CNTCVLREAD    | 0x0000 | Current value of Counter[31:0]       |
| CNTCVUREAD    | 0x0004 | Current value of Counter[63:32]      |
| PIDR4         | 0x0FD0 | Peripheral Identification Register 4 |
| PIDR5         | 0x0FD4 | Peripheral Identification Register 5 |
| PIDR6         | 0x0FD8 | Peripheral Identification Register 6 |
| PIDR7         | 0x0FDC | Peripheral Identification Register 7 |
| PIDR0         | 0x0FE0 | Peripheral Identification Register 0 |
| PIDR1         | 0x0FE4 | Peripheral Identification Register 1 |
| PIDR2         | 0x0FE8 | Peripheral Identification Register 2 |

| Register Name | Offset | Description                          |
|---------------|--------|--------------------------------------|
| PIDR3         | 0x0FEC | Peripheral Identification Register 3 |
| CIDR0         | 0x0FF0 | Component Identification Register 0  |
| CIDR1         | 0x0FF4 | Component Identification Register 1  |
| CIDR2         | 0x0FF8 | Component Identification Register 2  |
| CIDR3         | 0x0FFc | Component Identification Register 3  |

#### 2.2.5.3 TIMESTAMP\_CTRL Register List

| Register Name | Offset | Description                          |
|---------------|--------|--------------------------------------|
| CNTCR         | 0x0000 | Counter Control Register             |
| CNTSR         | 0x0004 | Counter Status Register              |
| CNTCVL        | 0x0008 | Current value of Counter[31:0]       |
| CNTCVU        | 0x000c | Current value of Counter[63:32]      |
| CNTFID0       | 0x0020 | Base Frequency ID register           |
| ITSTAT        | 0x0EF8 | Integration Test Status Register     |
| ITCTRL        | 0x0F00 | Integration Mode Control Register    |
| PIDR4         | 0x0FD0 | Peripheral Identification Register 4 |
| PIDR5         | 0x0FD4 | Peripheral Identification Register 5 |
| PIDR6         | 0x0FD8 | Peripheral Identification Register 6 |
| PIDR7         | 0x0FDC | Peripheral Identification Register 7 |
| PIDR0         | 0x0FE0 | Peripheral Identification Register 0 |
| PIDR1         | 0x0FE4 | Peripheral Identification Register 1 |
| PIDR2         | 0x0FE8 | Peripheral Identification Register 2 |
| PIDR3         | 0x0FEC | Peripheral Identification Register 3 |
| CIDR0         | 0x0FF0 | Component Identification Register 0  |
| CIDR1         | 0x0FF4 | Component Identification Register 1  |
| CIDR2         | 0x0FF8 | Component Identification Register 2  |
| CIDR3         | 0x0FFc | Component Identification Register 3  |

#### 2.2.5.4 CPU\_PLL\_CTRL Register List

| Register Name             | Offset | Description                           |
|---------------------------|--------|---------------------------------------|
| CPU_L_PLL_CTRL_REG        | 0x0004 | CPU_L_PLL Control Register            |
| CPU_DSU_PLL_CTRL_REG      | 0x0008 | CPU_DSU_PLL Control Register          |
| CPU_B_PLL_CTRL_REG        | 0x000c | CPU_B_PLL Control Register            |
| CPU_L_PLL_PAT0_CTRL_REG   | 0x0010 | CPU_L_PLL Pattern0 Control Register   |
| CPU_L_PLL_PAT1_CTRL_REG   | 0x0014 | CPU_L_PLL Pattern1 Control Register   |
| CPU_DSU_PLL_PAT0_CTRL_REG | 0x0018 | CPU_DSU_PLL Pattern0 Control Register |
| CPU_DSU_PLL_PAT1_CTRL_REG | 0x001c | CPU_DSU_PLL Pattern1 Control Register |
| CPU_B_PLL_PAT0_CTRL_REG   | 0x0020 | CPU_B_PLL Pattern0 Control Register   |
| CPU_B_PLL_PAT1_CTRL_REG   | 0x0024 | CPU_B_PLL Pattern1 Control Register   |

| Register Name        | Offset | Description                          |
|----------------------|--------|--------------------------------------|
| CPU_L_PLL_BIAS_REG   | 0x002c | CPU_L_PLL Bias Register              |
| CPU_DSU_PLL_BIAS_REG | 0x0030 | CPU_DSU_PLL Bias Register            |
| CPU_B_PLL_BIAS_REG   | 0x0034 | CPU_B_PLL Bias Register              |
| CPU_L_PLL_TUN0_REG   | 0x003C | CPU_L_PLL Tuning0 Control Register   |
| CPU_L_PLL_TUN1_REG   | 0x0040 | CPU_L_PLL Tuning1 Control Register   |
| CPU_DSU_PLL_TUN0_REG | 0x0044 | CPU_DSU_PLL Tuning0 Control Register |
| CPU_DSU_PLL_TUN1_REG | 0x0048 | CPU_DSU_PLL Tuning1 Control Register |
| CPU_B_PLL_TUN0_REG   | 0x004C | CPU_B_PLL Tuning0 Control Register   |
| CPU_B_PLL_TUN1_REG   | 0x0050 | CPU_B_PLL Tuning1 Control Register   |
| CPU_L_PLL_SSC_REG    | 0x0054 | CPU_L_PLL SSC Register               |
| CPU_DSU_PLL_SSC_REG  | 0x0058 | CPU_DSU_PLL SSC Register             |
| CPU_B_PLL_SSC_REG    | 0x005c | CPU_B_PLL SSC Register               |
| CPUA_CLK_REG         | 0x0060 | CPUA Clock Register                  |
| CPUB_CLK_REG         | 0x0064 | CPUB Clock Register                  |
| CPU_GATING_REG       | 0x0068 | CPU Gating Configuration Register    |
| DSU_CLK_REG          | 0x006c | DSU Clock Register                   |
| PLL_TEST_CLK_SEL     | 0x0070 | PLL Test Clock Selection Register    |

## 2.2.6 CPU\_SUBSYS\_CTRL Register Description

### 2.2.6.1 0x0000 General Control Register0 (Default Value: 0x0000\_0000)

| Offset: 0x0000 |            |             | Register Name: GENER_CTRL_REG0    |
|----------------|------------|-------------|-----------------------------------|
| Bit            | Read/Write | Default/Hex | Description                       |
| 31:2           | /          | /           | /                                 |
| 1              | R/W        | 0x0         | GICCDISABLE<br>DEBUGBLOCK Control |
| 0              | R/W        | 0x0         | CDBGRSTACK<br>Debug Reset ACK     |

### 2.2.6.2 0x000C GIC and JTAG Reset Control Register (Default Value: 0x0000\_003F)

| Offset: 0x000C |            |             | Register Name: GIC_JTAG_RST_CTRL                          |
|----------------|------------|-------------|-----------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                               |
| 31:20          | /          | /           | /                                                         |
| 19:16          | R/W        | 0x0         | EXM_CLR [3:0]<br>Clear the status of interface, for debug |
| 15:7           | /          | /           | /                                                         |
| 6              | R/W        | 0x1         | GIC_DBG_RSTN<br>GIC OUTRE Reset<br>0: Assert              |

| Offset: 0x000C |            |             | Register Name: GIC_JTAG_RST_CTRL                                          |
|----------------|------------|-------------|---------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                               |
|                |            |             | 1: De-assert.                                                             |
| 5              | R/W        | 0x1         | GIC_OUT_RSTN<br>GIC OUTRE Reset<br>0: Assert<br>1: De-assert.             |
| 4              | R/W        | 0x1         | GIC_OUT_MBIST_RSTN<br>GIC OUTER MBIST Reset<br>0: Assert<br>1: De-assert. |
| 3              | R/W        | 0x1         | COREPLL_RST<br>COREPLL Reset<br>0: Assert<br>1: De-assert.                |
| 2              | R/W        | 0x1         | CS_RST<br>CoreSight Reset<br>0: Assert<br>1: De-assert.                   |
| 1              | R/W        | 0x1         | PORTRST<br>JTAG Portrst<br>0: Assert<br>1: De-assert.                     |
| 0              | R/W        | 0x1         | TRST<br>Jtag TRST<br>0: Assert<br>1: De-assert.                           |

#### 2.2.6.3 0x001C Debug State Register (Default Value: 0x0000\_0000)

| Offset: 0x001C |            |             | Register Name: DBG_STATE |
|----------------|------------|-------------|--------------------------|
| Bit            | Read/Write | Default/Hex | Description              |
| 31:24          | R          | 0x0         | CLU_PWRSTW_STA           |
| 23:0           | /          | /           | /                        |

#### 2.2.6.4 0x0020 CPU0 Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0020 |            |             | Register Name: CPU0_CTRL_REG                     |
|----------------|------------|-------------|--------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                      |
| 31:1           | /          | /           | /                                                |
| 0              | R/W        | 0x0         | Cluster 0 CPU0 AA64NAA32<br>Register Width State |

| Offset: 0x0020 |            |             | Register Name: CPU0_CTRL_REG                                                        |
|----------------|------------|-------------|-------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                         |
|                |            |             | 0: AArch32<br>1: AArch64<br>This pin is sampled only during reset of the processor. |

#### 2.2.6.5 0x0024 CPU1 Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0024 |            |             | Register Name: CPU1_CTRL_REG                                                                                                            |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                             |
| 31:1           | /          | /           | /                                                                                                                                       |
| 0              | R/W        | 0x0         | Cluster 0 CPU1 AA64NAA32<br>Register Width State:<br>0: AArch32<br>1: AArch64<br>This pin is sampled only during reset of the processor |

#### 2.2.6.6 0x0028 CPU2 Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0028 |            |             | Register Name: CPU2_CTRL_REG                                                                                                             |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                              |
| 31:1           | /          | /           | /                                                                                                                                        |
| 0              | R/W        | 0x0         | Cluster 0 CPU2 AA64NAA32<br>Register Width State:<br>0: AArch32<br>1: AArch64<br>This pin is sampled only during reset of the processor. |

#### 2.2.6.7 0x002C CPU3 Control Register (Default Value: 0x0000\_0000)

| Offset: 0x002C |            |             | Register Name: CPU3_CTRL_REG                                                                                                             |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                              |
| 31:1           | /          | /           | /                                                                                                                                        |
| 0              | R/W        | 0x0         | Cluster 0 CPU3 AA64NAA32<br>Register Width State:<br>0: AArch32<br>1: AArch64<br>This pin is sampled only during reset of the processor. |

#### 2.2.6.8 0x0030 CPU4 Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0030 |            |             | Register Name: CPU4_CTRL_REG                                                                                                             |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                              |
| 31:1           | /          | /           | /                                                                                                                                        |
| 0              | R/W        | 0x0         | Cluster 0 CPU4 AA64NAA32<br>Register Width State:<br>0: AArch32<br>1: AArch64<br>This pin is sampled only during reset of the processor. |

#### 2.2.6.9 0x0034 CPU5 Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0034 |            |             | Register Name: CPU5_CTRL_REG                                                                                                             |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                              |
| 31:1           | /          | /           | /                                                                                                                                        |
| 0              | R/W        | 0x0         | Cluster 0 CPU5 AA64NAA32<br>Register Width State:<br>0: AArch32<br>1: AArch64<br>This pin is sampled only during reset of the processor. |

#### 2.2.6.10 0x0038 CPU6 Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0038 |            |             | Register Name: CPU6_CTRL_REG                                                                                                             |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                              |
| 31:1           | /          | /           | /                                                                                                                                        |
| 0              | R/W        | 0x0         | Cluster 0 CPU6 AA64NAA32<br>Register Width State:<br>0: AArch32<br>1: AArch64<br>This pin is sampled only during reset of the processor. |

#### 2.2.6.11 0x003C CPU7 Control Register (Default Value: 0x0000\_0000)

| Offset: 0x003C |            |             | Register Name: CPU7_CTRL_REG                                    |
|----------------|------------|-------------|-----------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                     |
| 31:1           | /          | /           | /                                                               |
| 0              | R/W        | 0x0         | Cluster 0 CPU7 AA64NAA32<br>Register Width State:<br>0: AArch32 |

| Offset: 0x003C |            |             | Register Name: CPU7_CTRL_REG                                          |
|----------------|------------|-------------|-----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                           |
|                |            |             | 1: AArch64<br>This pin is sampled only during reset of the processor. |

#### 2.2.6.12 0x0040 Reset Vector Base Address Register0\_L (Default Value: 0x0000\_0000)

| Offset: 0x0040 |            |             | Register Name: RVBARADDR0_L                                                                           |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                           |
| 31:2           | R/W        | 0x0         | RVBARADDR [31:2]<br>Reset Vector Base Address [39:2] for executing in 64-bit state (AArch64) of CPU0. |
| 1:0            | /          | /           | /                                                                                                     |

#### 2.2.6.13 0x0044 Reset Vector Base Address Register0\_H (Default Value: 0x0000\_0000)

| Offset: 0x0044 |            |             | Register Name: RVBARADDR0_H                                                                            |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                            |
| 31:8           | /          | /           | /                                                                                                      |
| 7:0            | R/W        | 0x0         | RVBARADDR [39:32]<br>Reset Vector Base Address [39:2] for executing in 64-bit state (AArch64) of CPU0. |

#### 2.2.6.14 0x0048 Reset Vector Base Address Register1\_L (Default Value: 0x0000\_0000)

| Offset: 0x0048 |            |             | Register Name: RVBARADDR1_L                                                                           |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                           |
| 31:2           | R/W        | 0x0         | RVBARADDR [31:2]<br>Reset Vector Base Address [39:2] for executing in 64-bit state (AArch64) of CPU1. |
| 1:0            | /          | /           | /                                                                                                     |

#### 2.2.6.15 0x004C Reset Vector Base Address Register1\_H (Default Value: 0x0000\_0000)

| Offset: 0x004C |            |             | Register Name: RVBARADDR1_H                                                                            |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                            |
| 31:8           | /          | /           | /                                                                                                      |
| 7:0            | R/W        | 0x0         | RVBARADDR [39:32]<br>Reset Vector Base Address [39:2] for executing in 64-bit state (AArch64) of CPU1. |

**2.2.6.16 0x0050 Reset Vector Base Address Register2\_L (Default Value: 0x0000\_0000)**

| Offset: 0x0050 |            |             | Register Name: RVBARADDR2_L                                                                           |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                           |
| 31:2           | R/W        | 0x0         | RVBARADDR [31:2]<br>Reset Vector Base Address [39:2] for executing in 64-bit state (AArch64) of CPU2. |
| 1:0            | /          | /           | /                                                                                                     |

**2.2.6.17 0x0054 Reset Vector Base Address Register2\_H (Default Value: 0x0000\_0000)**

| Offset: 0x0054 |            |             | Register Name: RVBARADDR2_H                                                                            |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                            |
| 31:8           | /          | /           | /                                                                                                      |
| 7:0            | R/W        | 0x0         | RVBARADDR [39:32]<br>Reset Vector Base Address [39:2] for executing in 64-bit state (AArch64) of CPU2. |

**2.2.6.18 0x0058 Reset Vector Base Address Register3\_L (Default Value: 0x0000\_0000)**

| Offset: 0x0058 |            |             | Register Name: RVBARADDR3_L                                                                           |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                           |
| 31:2           | R/W        | 0x0         | RVBARADDR [31:2]<br>Reset Vector Base Address [39:2] for executing in 64-bit state (AArch64) of CPU3. |
| 1:0            | /          | /           | /                                                                                                     |

**2.2.6.19 0x005C Reset Vector Base Address Register3\_H (Default Value: 0x0000\_0000)**

| Offset: 0x005C |            |             | Register Name: RVBARADDR3_H                                                                            |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                            |
| 31:8           | /          | /           | /                                                                                                      |
| 7:0            | R/W        | 0x0         | RVBARADDR [39:32]<br>Reset Vector Base Address [39:2] for executing in 64-bit state (AArch64) of CPU3. |

**2.2.6.20 0x0060 Reset Vector Base Address Register4\_L (Default Value: 0x0000\_0000)**

| Offset: 0x0060 |            |             | Register Name: RVBARADDR4_L |
|----------------|------------|-------------|-----------------------------|
| Bit            | Read/Write | Default/Hex | Description                 |
|                |            |             |                             |

| Offset: 0x0060 |            |             | Register Name: RVBARADDR4_L                                                                           |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                           |
| 31:2           | R/W        | 0x0         | RVBARADDR [31:2]<br>Reset Vector Base Address [39:2] for executing in 64-bit state (AArch64) of CPU4. |
| 1:0            | /          | /           | /                                                                                                     |

#### 2.2.6.21 0x0064 Reset Vector Base Address Register4\_H (Default Value: 0x0000\_0000)

| Offset: 0x0064 |            |             | Register Name: RVBARADDR4_H                                                                            |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                            |
| 31:8           | /          | /           | /                                                                                                      |
| 7:0            | R/W        | 0x0         | RVBARADDR [39:32]<br>Reset Vector Base Address [39:2] for executing in 64-bit state (AArch64) of CPU4. |

#### 2.2.6.22 0x0068 Reset Vector Base Address Register5\_L (Default Value: 0x0000\_0000)

| Offset: 0x0068 |            |             | Register Name: RVBARADDR5_L                                                                           |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                           |
| 31:2           | R/W        | 0x0         | RVBARADDR [31:2]<br>Reset Vector Base Address [39:2] for executing in 64-bit state (AArch64) of CPU5. |
| 1:0            | /          | /           | /                                                                                                     |

#### 2.2.6.23 0x006C Reset Vector Base Address Register5\_H (Default Value: 0x0000\_0000)

| Offset: 0x006C |            |             | Register Name: RVBARADDR5_H                                                                            |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                            |
| 31:8           | /          | /           | /                                                                                                      |
| 7:0            | R/W        | 0x0         | RVBARADDR [39:32]<br>Reset Vector Base Address [39:2] for executing in 64-bit state (AArch64) of CPU5. |

#### 2.2.6.24 0x0070 Reset Vector Base Address Register6\_L (Default Value: 0x0000\_0000)

| Offset: 0x0070 |            |             | Register Name: RVBARADDR6_L                                                                           |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                           |
| 31:2           | R/W        | 0x0         | RVBARADDR [31:2]<br>Reset Vector Base Address [39:2] for executing in 64-bit state (AArch64) of CPU6. |

| Offset: 0x0070 |            |             | Register Name: RVBARADDR6_L |
|----------------|------------|-------------|-----------------------------|
| Bit            | Read/Write | Default/Hex | Description                 |
| 1:0            | /          | /           | /                           |

#### 2.2.6.25 0x0074 Reset Vector Base Address Register6\_H (Default Value: 0x0000\_0000)

| Offset: 0x0074 |            |             | Register Name: RVBARADDR6_H                                                                            |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                            |
| 31:8           | /          | /           | /                                                                                                      |
| 7:0            | R/W        | 0x0         | RVBARADDR [39:32]<br>Reset Vector Base Address [39:2] for executing in 64-bit state (AArch64) of CPU6. |

#### 2.2.6.26 0x0078 Reset Vector Base Address Register7\_L (Default Value: 0x0000\_0000)

| Offset: 0x0078 |            |             | Register Name: RVBARADDR7_L                                                                           |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                           |
| 31:2           | R/W        | 0x0         | RVBARADDR [31:2]<br>Reset Vector Base Address [39:2] for executing in 64-bit state (AArch64) of CPU7. |
| 1:0            | /          | /           | /                                                                                                     |

#### 2.2.6.27 0x007C Reset Vector Base Address Register7\_H (Default Value: 0x0000\_0000)

| Offset: 0x007C |            |             | Register Name: RVBARADDR7_H                                                                            |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                            |
| 31:8           | /          | /           | /                                                                                                      |
| 7:0            | R/W        | 0x0         | RVBARADDR [39:32]<br>Reset Vector Base Address [39:2] for executing in 64-bit state (AArch64) of CPU7. |

#### 2.2.6.28 0x0140 PLL Control Register 0 (Default: 0x0000\_0007)

| Offset: 0x0140 |     |             | Register Name: PLL_CTRL_REG0                                          |
|----------------|-----|-------------|-----------------------------------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                                           |
| 31:25          | /   | /           | /                                                                     |
| 24             | R/W | 0x0         | TEST_CLK_SEL<br>Test Clock Selection<br>0: XTAL.<br>1: External Clock |
| 23:3           | /   | /           | /                                                                     |

| Offset: 0x0140 |     |             | Register Name: PLL_CTRL_REG0                               |
|----------------|-----|-------------|------------------------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                                |
| 2              | R/W | 0x1         | GM1<br>XTAL Gain Control Bit1                              |
| 1              | R/W | 0x1         | GM0<br>XTAL Gain Control Bit0                              |
| 0              | R/W | 0x1         | PLL_BIAS_EN<br>PLL Bias Enable<br>0: Disable<br>1: Enable. |

#### 2.2.6.29 0x0144 PLL Control Register 1 (Default: 0x00040005)

| Offset: 0x0144 |     |             | Register Name: PLL_CTRL_REG1                                                                                                                                                                                                                |
|----------------|-----|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                                                                                                                                                                                                                 |
| 31:24          | R/W | 0x0         | KEY_FIELD<br>Key Field for LDO Enable bit<br>If the key field value is 0xA7, the bit[23:0] can be modified.                                                                                                                                 |
| 23:19          | /   | /           | /                                                                                                                                                                                                                                           |
| 18:16          | R/W | 0x4         | PLLVDD_LDO_OUT_CTRL<br>PLLVDD LDO Output Control<br>000: 0.90 V<br>001: 0.94 V<br>010: 0.98 V<br>011: 1.02 V<br>100: 1.06 V<br>101: 1.10 V<br>110: 1.14 V<br>111: 1.18 V                                                                    |
| 15:5           | /   | /           | /                                                                                                                                                                                                                                           |
| 4              | R/W | 0x0         | MBIAS_EN<br>Chip Master Bias Enable<br>0: From Internal Bias<br>1: From ADDA Bias                                                                                                                                                           |
| 3              | R/W | 0x0         | PLLTEST_EN.<br>PLLTEST pin enable<br>For Verify (Back door clock PLLTEST enable).<br>0: Output clock is gated off.<br>1: Clock Output. The clock is the clock output to the PLL and the clock after frequency division through PLLTEST pin. |
| 2:1            | /   | /           | /                                                                                                                                                                                                                                           |
| 0              | R/W | 0x1         | LDO_EN.<br>PLL Power Enable                                                                                                                                                                                                                 |

| Offset: 0x0144 |     |             | Register Name: PLL_CTRL_REG1                             |
|----------------|-----|-------------|----------------------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                              |
|                |     |             | (The power source is VCC_PLL)<br>0: Disable<br>1: Enable |

## 2.2.7 TIMESTAMP\_STA Register Description

### 2.2.7.1 0x0000 Current value of Counter [31:0] Register (Default Value:0x0000\_0000)

| Offset: 0x0000 |            |             | Register Name: CNTCVLREAD                                             |
|----------------|------------|-------------|-----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                           |
| 31:0           | R          | 0x0         | CNTCVL32<br>The lower 32 bits of the current timestamp counter value. |

### 2.2.7.2 0x0004 Current value of Counter [63:32] Register (Default Value:0x0000\_0000)

| Offset: 0x0004 |            |             | Register Name: CNTCVUREAD                                             |
|----------------|------------|-------------|-----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                           |
| 31:0           | R          | 0x0         | CNTCVU32<br>The upper 32 bits of the current timestamp counter value. |

### 2.2.7.3 0x0FD0 Peripheral Identification Register 4 Register (Default Value:0x0000\_0004)

| Offset: 0x0FD0 |            |             | Register Name: PIDR4                                                                                                                                                                                                         |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                  |
| 31:8           | R          | 0x0         | RES0<br>Reserved bit or field with Should-Be-Zero-or-Preserved (SBZP) behavior.                                                                                                                                              |
| 7:4            | R          | 0x0         | SIZE<br>Indicates the memory size that is used by this component.<br>Returns 0 indicating that the component uses an UNKNOWN number of 4KB blocks. Using the SIZE field to indicate the size of the component is deprecated. |
| 3:0            | R          | 0x4         | DES_2<br>JEP106 continuation code. Together, with PIDR2.DES_1 and PIDR1.DES_0, they indicate the designer of the component and not the implementer, except where the two are the same.                                       |

#### 2.2.7.4 0x0FD4 Peripheral Identification Register 5 Register (Default Value:0x0000\_0000)

| Offset: 0x0FD4 |            |             | Register Name: PIDR5                                                            |
|----------------|------------|-------------|---------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                     |
| 31:8           | R          | 0x0         | RES0<br>Reserved bit or field with Should-Be-Zero-or-Preserved (SBZP) behavior. |
| 7:0            | R          | 0x0         | PIDR5<br>Reserved                                                               |

#### 2.2.7.5 0x0FD8 Peripheral Identification Register 6 Register (Default Value:0x0000\_0000)

| Offset: 0x0FD8 |            |             | Register Name: PIDR6                                                            |
|----------------|------------|-------------|---------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                     |
| 31:8           | R          | 0x0         | RES0<br>Reserved bit or field with Should-Be-Zero-or-Preserved (SBZP) behavior. |
| 7:0            | R          | 0x0         | PIDR6<br>Reserved                                                               |

#### 2.2.7.6 0x0FDC Peripheral Identification Register 7 Register (Default Value:0x0000\_0000)

| Offset: 0x0FDC |            |             | Register Name: PIDR7                                                            |
|----------------|------------|-------------|---------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                     |
| 31:8           | R          | 0x0         | RES0<br>Reserved bit or field with Should-Be-Zero-or-Preserved (SBZP) behavior. |
| 7:0            | R          | 0x0         | PIDR7<br>Reserved                                                               |

#### 2.2.7.7 0x0FE0 Peripheral Identification Register 0 Register (Default Value:0x0000\_0093)

| Offset: 0x0FE0 |            |             | Register Name: PIDR0                                                                                                                                          |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                   |
| 31:8           | R          | 0x0         | RES0<br>Reserved bit or field with Should-Be-Zero-or-Preserved (SBZP) behavior.                                                                               |
| 7:0            | R          | 0x93        | PART_0<br>Part number, bits [7:0]. Taken together with PIDR1.PART_1 it indicates the component. The Part Number is selected by the designer of the component. |

### 2.2.7.8 0x0FE4 Peripheral Identification Register 1 Register (Default Value:0x0000\_00B1)

| Offset: 0x0FE4 |            |             | Register Name: PIDR1                                                                                                                                                                                 |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                          |
| 31:8           | R          | 0x0         | RES0<br>Reserved bit or field with Should-Be-Zero-or-Preserved (SBZP) behavior.                                                                                                                      |
| 7:4            | R          | 0xB         | DES_0<br>JEP106 identification code, bits [3:0]. Together, with PIDR4.DES_2 and PIDR2.DES_1, they indicate the designer of the component and not the implementer, except where the two are the same. |
| 3:0            | R          | 0x1         | PART_1<br>Part number, bits [11:8]. Taken together with PIDR0.PART_0 it indicates the component. The Part Number is selected by the designer of the component.                                       |

### 2.2.7.9 0x0FE8 Peripheral Identification Register 2 Register (Default Value:0x0000\_000B)

| Offset: 0x0FE8 |            |             | Register Name: PIDR2                                                                                                                                                                                   |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                            |
| 31:8           | R          | 0x0         | RES0<br>Reserved bit or field with Should-Be-Zero-or-Preserved (SBZP) behavior.                                                                                                                        |
| 7:4            | R          | 0x0         | REVISION<br>Revision. It is an incremental value starting at 0x0 for the first design of a component. See the css600 Component list in Chapter 1 for information on the RTL revision of the component. |
| 3              | R          | 0x1         | JEDEC<br>1 - Always set. Indicates that a JEDEC assigned value is used.                                                                                                                                |
| 2:0            | R          | 0x3         | DES_1<br>JEP106 identification code, bits [6:4]. Together, with PIDR4.DES_2 and PIDR1.DES_0, they indicate the designer of the component and not the implementer, except where the two are the same.   |

### 2.2.7.10 0x0FEC Peripheral Identification Register 3 Register (Default Value:0x0000\_0000)

| Offset: 0x0FEC |            |             | Register Name: PIDR3 |
|----------------|------------|-------------|----------------------|
| Bit            | Read/Write | Default/Hex | Description          |
| 31:8           | R          | 0x0         | RES0                 |

| Offset: 0x0FEC |            |             | Register Name: PIDR3                                                                                                                                                             |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                      |
|                |            |             | Reserved bit or field with Should-Be-Zero-or-Preserved (SBZP) behavior.                                                                                                          |
| 7:4            | R          | 0x0         | REVAND<br>This field indicates minor errata fixes specific to this design, for example metal fixes after implementation. In most cases this field is 0x0.                        |
| 3:0            | R          | 0x0         | CMOD<br>Customer Modified. Where the component is reusable IP, this value indicates if the customer has modified the behavior of the component. In most cases this field is 0x0. |

#### 2.2.7.11 0x0FF0 Component Identification Register 0 Register (Default Value:0x0000\_000D)

| Offset: 0x0FF0 |            |             | Register Name: CIDR0                                                            |
|----------------|------------|-------------|---------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                     |
| 31:8           | R          | 0x0         | RES0<br>Reserved bit or field with Should-Be-Zero-or-Preserved (SBZP) behavior. |
| 7:0            | R          | 0x0D        | PRMBL_0<br>Preamble. Returns 0x0D.                                              |

#### 2.2.7.12 0x0FF4 Component Identification Register 1 Register (Default Value:0x0000\_00F0)

| Offset: 0x0FF4 |            |             | Register Name: CIDR1                                                                        |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                 |
| 31:8           | R          | 0x0         | RES0<br>Reserved bit or field with Should-Be-Zero-or-Preserved (SBZP) behavior.             |
| 7:4            | R          | 0xF         | CLASS<br>Component class. Returns 0xF, indicating CoreLink, PrimeCell, or system component. |
| 3:0            | R          | 0x0         | PRMBL_1<br>Preamble. Returns 0x0.                                                           |

#### 2.2.7.13 0x0FF8 Component Identification Register 2 Register (Default Value:0x0000\_0005)

| Offset: 0x0FF8 |            |             | Register Name: CIDR2 |
|----------------|------------|-------------|----------------------|
| Bit            | Read/Write | Default/Hex | Description          |
| 31:8           | R          | 0x0         | RES0                 |

| Offset: 0xFF8 |            |             | Register Name: CIDR2                                                    |
|---------------|------------|-------------|-------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                             |
|               |            |             | Reserved bit or field with Should-Be-Zero-or-Preserved (SBZP) behavior. |
| 7:0           | R          | 0x05        | PRMBL_2<br>Preamble. Returns 0x05.                                      |

#### 2.2.7.14 0xFFC Component Identification Register 3 Register (Default Value:0x0000\_00B1)

| Offset: 0xFFC |            |             | Register Name: CIDR3                                                            |
|---------------|------------|-------------|---------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                     |
| 31:8          | R          | 0x0         | RES0<br>Reserved bit or field with Should-Be-Zero-or-Preserved (SBZP) behavior. |
| 7:0           | R          | 0xB1        | PRMBL_3<br>Preamble. Returns 0xB1.                                              |

### 2.2.8 TIMESTAMP\_CTRL Register Description

#### 2.2.8.1 0x0000 Counter Control Register (Default Value:0x0000\_0000)

| Offset: 0x0000 |            |             | Register Name: CNTCR                                                                                                                                                                          |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                   |
| 31:2           | /          | /           | /                                                                                                                                                                                             |
| 1              | R/W        | 0x0         | HDBG<br>Halt On Debug<br>0 Do not halt on debug. The HALT_REQ signal into the counter has no effect.<br>1 Halt on debug. When the HALT_REQ pulse is received, the count value is held static. |
| 0              | R/W        | 0x0         | EN<br>Enable Bit<br>0 The counter is disabled. Count is not incrementing.<br>1 The counter is enabled. Count is incrementing.                                                                 |

#### 2.2.8.2 0x0004 Counter Status Register (Default Value:0x0000\_0000)

| Offset: 0x0004 |            |             | Register Name: CNTSR |
|----------------|------------|-------------|----------------------|
| Bit            | Read/Write | Default/Hex | Description          |
| 31:2           | /          | /           | /                    |
| 1              | R          | 0x0         | DBGH                 |

| Offset: 0x0004 |            |             | Register Name: CNTSR                                         |
|----------------|------------|-------------|--------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                  |
|                |            |             | Debug status.<br>0 Debug is halted<br>1 Debug is not halted. |
| 0              | /          | /           | /                                                            |

#### 2.2.8.3 0x0008 Current value of Counter [31:0] Register (Default Value:0x0000\_0000)

| Offset: 0x0008 |            |             | Register Name: CNTCVL                                                                                                                                                                                                                                                                                                        |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                  |
| 31:0           | R/W        | 0x0         | CNTCVL32<br>Reads to this register return the lower 32 bits of the current timestamp counter value. To change the current timestamp value, write the lower 32 bits of the new value to this register before writing the upper 32 bits to CNTCVU. The timestamp value is not changed until the CNTCVU register is written to. |

#### 2.2.8.4 0x000C Current value of Counter [63:32] Register (Default Value:0x0000\_0000)

| Offset: 0x000C |            |             | Register Name: CNTCVU                                                                                                                                                                                                                                                                                                                                    |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                              |
| 31:0           | R/W        | 0x0         | CNTCVU32<br>Reads to this register return the upper 32 bits of the current timestamp counter value. To change the current timestamp value, write the lower 32 bits of the new value to CNTCVL before writing the upper 32 bits to this register. The 64-bit timestamp value is updated with the value from both writes when this register is written to. |

#### 2.2.8.5 0x0020 Base Frequency ID Register (Default Value:0x0000\_0000)

| Offset: 0x0020 |            |             | Register Name: CNTFID0                                                        |
|----------------|------------|-------------|-------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                   |
| 31:0           | R/W        | 0x0         | Freq<br>Frequency in number of ticks per second. Up to 4GHz can be specified. |

#### 2.2.8.6 0x0EF8 Integration Test Status Register (Default Value:0x0000\_0000)

|                |                       |
|----------------|-----------------------|
| Offset: 0x0EF8 | Register Name: ITSTAT |
|----------------|-----------------------|

| Bit  | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                            |
|------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2 | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 1    | R          | 0x0         | ITTRESTARTREQ<br>Integration Test Restart Request status of the RESTART_REQ input. Integration testing mode:Behaves as a sticky bit and latches to 1 when TSGEN receives restart request. Cleared on reading this register. If RESTART_REQ is asserted in the same cycle as an APB read of this register, the read takes priority and the register is cleared as a result. Always returns 0 in normal functional mode. |
| 0    | R          | 0x0         | ITHALTREQ<br>Integration Test Halt Request status of the HALT_REQ input. Integration testing mode: Behaves as a sticky bit and latches to 1 when TSGEN receives halt request. Cleared on reading this register. If HALT_REQ is asserted in the same cycle as an APB read of this register, the read takes priority and the register is cleared as a result. Always returns 0 in normal functional mode.                |

#### 2.2.8.7 0x0F00 Integration Mode Control Register (Default Value:0x0000\_0000)

| Offset: 0x0F00 |            |             | Register Name: ITCTRL                                                                                                                                |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                          |
| 31:1           | /          | /           | /                                                                                                                                                    |
| 0              | R/W        | 0x0         | IME<br>Integration Mode Enable. When set, the component enters integration mode, enabling topology detection or integration testing to be performed. |

#### 2.2.8.8 0x0FD0 Peripheral Identification Register 4 Register (Default Value:0x0000\_0004)

| Offset: 0x0FD0 |            |             | Register Name: PIDR4                                                                                                                                                                                                      |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                               |
| 31:8           | R          | 0x0         | RES0<br>Reserved bit or field with Should-Be-Zero-or-Preserved (SBZP) behavior.                                                                                                                                           |
| 7:4            | R          | 0x0         | SIZE<br>Indicates the memory size that is used by this component. Returns 0 indicating that the component uses an UNKNOWN number of 4KB blocks. Using the SIZE field to indicate the size of the component is deprecated. |
| 3:0            | R          | 0x4         | DES_2                                                                                                                                                                                                                     |

| Offset: 0x0FD0 |            |             | Register Name:PIDR4                                                                                                                                                           |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                   |
|                |            |             | JEP106 continuation code. Together, with PIDR2.DES_1 and PIDR1.DES_0, they indicate the designer of the component and not the implementer, except where the two are the same. |

#### 2.2.8.9 0x0FD4 Peripheral Identification Register 5 Register (Default Value:0x0000\_0000)

| Offset: 0x0FD4 |            |             | Register Name:PIDR5                                                             |
|----------------|------------|-------------|---------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                     |
| 31:8           | R          | 0x0         | RES0<br>Reserved bit or field with Should-Be-Zero-or-Preserved (SBZP) behavior. |
| 7:0            | R          | 0x0         | PIDR5<br>Reserved                                                               |

#### 2.2.8.10 0x0FD8 Peripheral Identification Register 6 Register (Default Value:0x0000\_0000)

| Offset: 0x0FD8 |            |             | Register Name:PIDR6                                                             |
|----------------|------------|-------------|---------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                     |
| 31:8           | R          | 0x0         | RES0<br>Reserved bit or field with Should-Be-Zero-or-Preserved (SBZP) behavior. |
| 7:0            | R          | 0x0         | PIDR6<br>Reserved                                                               |

#### 2.2.8.11 0x0FDC Peripheral Identification Register 7 Register (Default Value:0x0000\_0000)

| Offset: 0x0FDC |            |             | Register Name:PIDR7                                                             |
|----------------|------------|-------------|---------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                     |
| 31:8           | R          | 0x0         | RES0<br>Reserved bit or field with Should-Be-Zero-or-Preserved (SBZP) behavior. |
| 7:0            | R          | 0x0         | PIDR7<br>Reserved                                                               |

#### 2.2.8.12 0x0FE0 Peripheral Identification Register 0 Register (Default Value:0x0000\_0093)

| Offset: 0x0FE0 |            |             | Register Name:PIDR0 |
|----------------|------------|-------------|---------------------|
| Bit            | Read/Write | Default/Hex | Description         |

| Offset: 0x0FE0 |            |             | Register Name:PIDR0                                                                                                                                           |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                   |
| 31:8           | R          | 0x0         | RES0<br>Reserved bit or field with Should-Be-Zero-or-Preserved (SBZP) behavior.                                                                               |
| 7:0            | R          | 0x93        | PART_0<br>Part number, bits [7:0]. Taken together with PIDR1.PART_1 it indicates the component. The Part Number is selected by the designer of the component. |

#### 2.2.8.13 0x0FE4 Peripheral Identification Register 1 Register (Default Value:0x0000\_00B1)

| Offset: 0x0FE4 |            |             | Register Name:PIDR1                                                                                                                                                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                          |
| 31:8           | R          | 0x0         | RES0<br>Reserved bit or field with Should-Be-Zero-or-Preserved (SBZP) behavior.                                                                                                                      |
| 7:4            | R          | 0xB         | DES_0<br>JEP106 identification code, bits [3:0]. Together, with PIDR4.DES_2 and PIDR2.DES_1, they indicate the designer of the component and not the implementer, except where the two are the same. |
| 3:0            | R          | 0x1         | PART_1<br>Part number, bits [11:8]. Taken together with PIDR0.PART_0 it indicates the component. The Part Number is selected by the designer of the component.                                       |

#### 2.2.8.14 0x0FE8 Peripheral Identification Register 2 Register (Default Value:0x0000\_000B)

| Offset: 0x0FE8 |             |              | Register Name:PIDR2                                                                                                                                                                                                                                                                               |
|----------------|-------------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Writ e | Default/H ex | Description                                                                                                                                                                                                                                                                                       |
| 31:<br>8       | R           | 0x0          | RES0<br>Reserved bit or field with Should-Be-Zero-or-Preserved (SBZP) behavior.                                                                                                                                                                                                                   |
| 7:4            | R           | 0x0          | REVISION<br>Revision. It is an incremental value starting at 0x0 for the first design of a component. For information on the RTL revision of the component, see the css600 Component list in chapter 1 of <a href="#"><i>coresight_soc600_technical_reference_manual_100806_0300_0_en.pdf</i></a> |
| 3              | R           | 0x1          | JEDEC                                                                                                                                                                                                                                                                                             |

| Offset: 0x0FE8 |            |             | Register Name:PIDR2                                                                                                                                                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                          |
|                |            |             | 1: Always set. Indicates that a JEDEC assigned value is used.                                                                                                                                        |
| 2:0            | R          | 0x3         | DES_1<br>JEP106 identification code, bits [6:4]. Together, with PIDR4.DES_2 and PIDR1.DES_0, they indicate the designer of the component and not the implementer, except where the two are the same. |

#### 2.2.8.15 0x0FEC Peripheral Identification Register 3 Register (Default Value:0x0000\_0000)

| Offset: 0x0FEC |            |             | Register Name:PIDR3                                                                                                                                                              |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                      |
|                |            |             | RES0<br>Reserved bit or field with Should-Be-Zero-or-Preserved (SBZP) behavior.                                                                                                  |
| 7:4            | R          | 0x0         | REVAND<br>This field indicates minor errata fixes specific to this design, for example metal fixes after implementation. In most cases this field is 0x0.                        |
| 3:0            | R          | 0x0         | CMOD<br>Customer Modified. Where the component is reusable IP, this value indicates if the customer has modified the behavior of the component. In most cases this field is 0x0. |

#### 2.2.8.16 0x0FF0 Component Identification Register 0 Register (Default Value:0x0000\_000D)

| Offset: 0x0FF0 |            |             | Register Name:CIDR0                                                             |
|----------------|------------|-------------|---------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                     |
|                |            |             | RES0<br>Reserved bit or field with Should-Be-Zero-or-Preserved (SBZP) behavior. |
| 7:0            | R          | 0x0D        | PRMBL_0<br>Preamble. Returns 0x0D.                                              |

#### 2.2.8.17 0x0FF4 Component Identification Register 1 Register (Default Value:0x0000\_00F0)

| Offset: 0x0FF4 |            |             | Register Name:CIDR1                                            |
|----------------|------------|-------------|----------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                    |
| 31:8           | R          | 0x0         | RES0<br>Reserved bit or field with Should-Be-Zero-or-Preserved |

| Offset: 0x0FF4 |            |             | Register Name: CIDR1                                                                        |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                 |
|                |            |             | (SBZP) behavior.                                                                            |
| 7:4            | R          | 0xF         | CLASS<br>Component class. Returns 0xF, indicating CoreLink, PrimeCell, or system component. |
| 3:0            | R          | 0x0         | PRMBL_1<br>Preamble. Returns 0x0.                                                           |

#### 2.2.8.18 0x0FF8 Component Identification Register 2 Register (Default Value:0x0000\_0005)

| Offset: 0x0FF8 |            |             | Register Name: CIDR2                                                            |
|----------------|------------|-------------|---------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                     |
|                |            |             | RES0<br>Reserved bit or field with Should-Be-Zero-or-Preserved (SBZP) behavior. |
| 31:8           | R          | 0x0         |                                                                                 |
| 7:0            | R          | 0x05        | PRMBL_2<br>Preamble. Returns 0x05.                                              |

#### 2.2.8.19 0x0FFC Component Identification Register 3 Register (Default Value:0x0000\_00B1)

| Offset: 0x0FFC |            |             | Register Name: CIDR3                                                            |
|----------------|------------|-------------|---------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                     |
|                |            |             | RES0<br>Reserved bit or field with Should-Be-Zero-or-Preserved (SBZP) behavior. |
| 31:8           | R          | 0x0         |                                                                                 |
| 7:0            | R          | 0xB1        | PRMBL_3<br>Preamble. Returns 0xB1.                                              |

### 2.2.9 CPU\_PLL\_CFG Register Description

#### 2.2.9.1 0x0004 CPU\_L\_PLL Control Register (Default Value: 0x4880\_1400)

| Offset: 0x0004 |            |             | Register Name: CPU_L_PLL_CTRL_REG                                                                                                                |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                      |
| 31             | R/W        | 0x0         | PLL_EN.<br>PLL Enable<br>0: Disable<br>1: Enable<br>The CPU_L_PLL= InputFreq*N/P/(M0*M1).<br>Note: The CPU_L_PLL output frequency must be in the |

| Offset: 0x0004 |            |             | Register Name: CPU_L_PLL_CTRL_REG                                                                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                        |
|                |            |             | range from 480 MHz to 2.6 GHz. And the default value of CPU_L_PLL is 480 MHz when the crystal oscillator is 24 MHz.                |
| 30             | R/W        | 0x1         | PLL_LDO_EN.<br>LDO Enable.<br>0: Disable<br>1: Enable                                                                              |
| 29             | R/W        | 0x0         | LOCK_ENABLE<br>Lock Enable.<br>0: Disable<br>1: Enable                                                                             |
| 28             | R          | 0x0         | LOCK<br>PLL Lock INFO.<br>0: Unlocked<br>1: Locked (It indicates that the PLL has been stable.)                                    |
| 27             | R/W        | 0x1         | PLL_OUTPUT_GATE<br>PLL Output Gating Enable<br>0: Disable<br>1: Enable<br>The bit is used to control the output enable of the PLL. |
| 26             | R/WAC      | 0x0         | PLL_UPDATE<br>Write q update the CFG to PLL, auto clear.                                                                           |
| 25:24          | /          | /           | /                                                                                                                                  |
| 23             | R/W        | 0x1         | PLL_NDET                                                                                                                           |
| 22             | R/W        | 0x0         | PLL_TDIV                                                                                                                           |
| 21:20          | R/W        | 0x0         | PLL_M0<br>M0 = PLL_M0 + 1<br>PLL_FACTOR_M0 is from 0 to 3.                                                                         |
| 19:16          | R/W        | 0x0         | PLL_P<br>PLL PREDIV P<br>P = PLL_P + 1                                                                                             |
| 15:8           | R/W        | 0x14        | PLL_N<br>PLL N<br>N= PLL_N                                                                                                         |
| 7:6            | R/W        | 0x0         | PLL_UNLOCK_MDSEL<br>PLL Unlock Level<br>00: 21-29 Clock Cycles<br>01: 22-28 Clock Cycles                                           |

| Offset: 0x0004 |            |             | Register Name: CPU_L_PLL_CTRL_REG                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                        |
|                |            |             | 1X: 20-30 Clock Cycles                                                             |
| 5              | R/W        | 0x0         | PLL_LOCK_MDSEL<br>PLL Lock Level<br>0: 24-26 Clock Cycles<br>1: 23-27 Clock Cycles |
| 4              | /          | /           | /                                                                                  |
| 3:0            | R/W        | 0x0         | PLL_M1<br>PLL_M1<br>M1 = PLL_M1 + 1<br>PLL_M1 is from 0 to 15.                     |

#### 2.2.9.2 0x0008 CPU\_DSU\_PLL Control Register (Default Value: 0x4880\_1400)

| Offset: 0x0008 |            |             | Register Name: CPU_DSU_PLL_CTRL_REG                                                                                                                                                                                                                                     |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                             |
| 31             | R/W        | 0x0         | PLL_EN<br>PLL Enable<br>0: Disable<br>1: Enable<br>The CPU_DSU_PLL= InputFreq*N/P/(M0*M1).<br>Note: The CPU_DSU_PLL output frequency must be in the range from 200 MHz to 3 GHz. And the default value of CPU_DSU_PLL is 408 MHz when the crystal oscillator is 24 MHz. |
| 30             | R/W        | 0x1         | PLL_LDO_EN<br>LDO Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                                                     |
| 29             | R/W        | 0x0         | LOCK_ENABLE<br>Lock Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                                                   |
| 28             | R          | 0x0         | LOCK<br>PLL Lock info<br>0: Unlocked<br>1: Locked (It indicates that the PLL has been stable.)                                                                                                                                                                          |
| 27             | R/W        | 0x1         | PLL_OUTPUT_GATE<br>PLL Output Gating Enable.<br>0: Disable<br>1: Enable<br>The bit is used to control the output enable of the PLL.                                                                                                                                     |

| Offset: 0x0008 |            |             | Register Name: CPU_DSU_PLL_CTRL_REG                                                                                |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                        |
| 26             | R/WAC      | 0x0         | PLL_UPDATE<br>Write q update the CFG to PLL, auto clear.                                                           |
| 25:24          | /          | /           | /                                                                                                                  |
| 23             | R/W        | 0x1         | PLL_NDET                                                                                                           |
| 22             | R/W        | 0x0         | PLL_TDIV                                                                                                           |
|                |            |             | PLL_M0                                                                                                             |
| 21:20          | R/W        | 0x0         | M0 = PLL_M0 + 1<br>PLL_FACTOR_M0 is from 0 to 15.                                                                  |
| 19:16          | R/W        | 0x0         | PLL_P<br>PLL PREDIV P<br>P = PLL_P + 1                                                                             |
| 15:8           | R/W        | 0x14        | PLL_N<br>PLL N<br>N= PLL_N                                                                                         |
| 7:6            | R/W        | 0x0         | PLL_UNLOCK_MDSEL<br>PLL Unlock Level<br>00: 21-29 Clock Cycles<br>01: 22-28 Clock Cycles<br>1X: 20-30 Clock Cycles |
| 5              | R/W        | 0x0         | PLL_LOCK_MDSEL<br>PLL Lock Level.<br>0: 24-26 Clock Cycles<br>1: 23-27 Clock Cycles                                |
| 4              | /          | /           | /                                                                                                                  |
| 3:0            | R/W        | 0x0         | PLL_M1<br>M1 = PLL_M1 + 1<br>PLL_M1 is from 0 to 15.                                                               |

### 2.2.9.3 0x000C CPU\_B\_PLL Control Register (Default Value: 0x4880\_1400)

| Offset: 0x000C |            |             | Register Name: CPU_B_PLL_CTRL_REG                                                                                                                                                                                                                              |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                    |
| 31             | R/W        | 0x0         | PLL_EN<br>PLL Enable<br>0: Disable<br>1: Enable<br>The CPU_B_PLL= InputFreq*N/P/(M0*M1).<br>Note: The CPU_B_PLL output frequency must be in the range from 480 MHz to 2.6 GHz. And the default value of CPU_B_PLL is 480 MHz when the crystal oscillator is 24 |

| Offset: 0x000C |            |             | Register Name: CPU_B_PLL_CTRL_REG                                                                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                        |
|                |            |             | MHz.                                                                                                                               |
| 30             | R/W        | 0x1         | PLL_LDO_EN.<br>LDO Enable.<br>0: Disable<br>1: Enable                                                                              |
| 29             | R/W        | 0x0         | LOCK_ENABLE<br>Lock Enable.<br>0: Disable<br>1: Enable                                                                             |
| 28             | R          | 0x0         | LOCK<br>PLL Lock INFO<br>0: Unlocked<br>1: Locked (It indicates that the PLL has been stable.)                                     |
| 27             | R/W        | 0x1         | PLL_OUTPUT_GATE<br>PLL Output Gating Enable<br>0: Disable<br>1: Enable<br>The bit is used to control the output enable of the PLL. |
| 26             | R/WAC      | 0x0         | PLL_UPDATE<br>Write q update the CFG to PLL, auto clear.                                                                           |
| 25:24          | /          | /           | /                                                                                                                                  |
| 23             | R/W        | 0x1         | PLL_NDET                                                                                                                           |
| 22             | R/W        | 0x0         | PLL_TDIV                                                                                                                           |
| 21:20          | R/W        | 0x0         | PLL_M0<br>M0 = PLL_M0 + 1<br>PLL_FACTOR_M0 is from 0 to 15.                                                                        |
| 19:16          | R/W        | 0x0         | PLL_P<br>P = PLL_P + 1                                                                                                             |
| 15:8           | R/W        | 0x14        | PLL_N<br>N= PLL_N                                                                                                                  |
| 7:6            | R/W        | 0x0         | PLL_UNLOCK_MDSEL<br>PLL Unlock Level<br>00: 21-29 Clock Cycles<br>01: 22-28 Clock Cycles<br>1X: 20-30 Clock Cycles                 |
| 5              | R/W        | 0x0         | PLL_LOCK_MDSEL<br>PLL Lock Level                                                                                                   |

| Offset: 0x000C |            |             | Register Name: CPU_B_PLL_CTRL_REG                   |
|----------------|------------|-------------|-----------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                         |
|                |            |             | 0: 24-26 Clock Cycles<br>1: 23-27 Clock Cycles      |
| 4              | /          | /           | /                                                   |
| 3:0            | R/W        | 0x0         | PLL_M1<br>M1 = PLL_M1 + 1<br>PLL_M1 is from 0 to 15 |

#### 2.2.9.4 0x0010 CPU\_L\_PLL Pattern0 Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0010 |            |             | Register Name: CPU_L_PLL_PAT0_CTRL_REG                                                                            |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                       |
| 31             | R/W        | 0x0         | SIG_DELT_PAT_EN<br>Sigma Delta Pattern Enable                                                                     |
| 30:29          | R/W        | 0x0         | SPR_FREQ_MODE<br>Spread Frequency Mode<br>00: DC=0<br>01: DC=1<br>10: Triangular (1bit)<br>11: Triangular (n bit) |
| 28:17          | R/W        | 0x0         | WAVE_STEP<br>Wave Step                                                                                            |
| 16:0           | R/W        | 0x0         | WAVE_BOT<br>Wave Bottom                                                                                           |

#### 2.2.9.5 0x0014 CPU\_L\_PLL Pattern1 Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0014 |            |             | Register Name: CPU_L_PLL_PAT1_CTRL_REG                |
|----------------|------------|-------------|-------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                           |
| 31:22          | R/W        | 0x0         | SDM_CYCLE<br>SDM Cycle<br>SDM_CYCLE=SDM_FRE/CLK_SDM/2 |
| 21             | /          | /           | /                                                     |
| 20             | R/W        | 0x0         | SDM_DIRECTION<br>SDM direction<br>0: UP<br>1: DOWM    |
| 19             | /          | /           | /                                                     |
| 18             | R/W        | 0x0         | DITHER_EN<br>Dither Enable                            |
| 17             | R/W        | 0x0         | FRAC_EN                                               |

| Offset: 0x0014 |            |             | Register Name: CPU_L_PLL_PAT1_CTRL_REG |
|----------------|------------|-------------|----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                            |
|                |            |             | Fraction Enable                        |
| 16:0           | R/W        | 0x0         | FRAC_IN<br>Fraction In                 |

#### 2.2.9.6 0x0018 CPU\_DSU\_PLL Pattern0 Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0018 |            |             | Register Name: CPU_DSU_PLL_PAT0_CTRL_REG                                                                          |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                       |
| 31             | R/W        | 0x0         | SIG_DELT_PAT_EN<br>Sigma Delta Pattern Enable                                                                     |
| 30:29          | R/W        | 0x0         | SPR_FREQ_MODE<br>Spread Frequency Mode<br>00: DC=0<br>01: DC=1<br>10: Triangular (1bit)<br>11: Triangular (n bit) |
| 28:17          | R/W        | 0x0         | WAVE_STEP<br>Wave Step                                                                                            |
| 16:0           | R/W        | 0x0         | WAVE_BOT<br>Wave Bottom                                                                                           |

#### 2.2.9.7 0x001C CPU\_DSU\_PLL Pattern1 Control Register (Default Value: 0x0000\_0000)

| Offset: 0x001C |            |             | Register Name: CPU_DSU_PLL_PAT1_CTRL_REG              |
|----------------|------------|-------------|-------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                           |
| 31:22          | R/W        | 0x0         | SDM_CYCLE<br>SDM Cycle<br>SDM_CYCLE=SDM_FRE/CLK_SDM/2 |
| 21             | /          | /           | /                                                     |
| 20             | R/W        | 0x0         | SDM_DIRECTION.<br>SDM direction.<br>0: UP<br>1: DOWM  |
| 19             | /          | /           | /                                                     |
| 18             | R/W        | 0x0         | DITHER_EN<br>Dither Enable                            |
| 17             | R/W        | 0x0         | FRAC_EN<br>Fraction Enable                            |
| 16:0           | R/W        | 0x0         | FRAC_IN<br>Fraction In                                |

### 2.2.9.8 0x0020 CPU\_B\_PLL Pattern0 Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0020 |            |             | Register Name: CPU_B_PLL_PAT0_CTRL_REG                                                                             |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                        |
| 31             | R/W        | 0x0         | SIG_DELTA_PAT_EN<br>Sigma Delta Pattern Enable                                                                     |
| 30:29          | R/W        | 0x0         | SPR_FREQ_MODE<br>Spread Frequency Mode<br>00: DC=0<br>01: DC=1<br>10: Triangular (1 bit)<br>11: Triangular (n bit) |
| 28:17          | R/W        | 0x0         | WAVE_STEP<br>Wave Step                                                                                             |
| 16:0           | R/W        | 0x0         | WAVE_BOT<br>Wave Bottom                                                                                            |

### 2.2.9.9 0x0024 CPU\_B\_PLL Pattern1 Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0024 |            |             | Register Name: CPU_B_PLL_PAT1_CTRL_REG                |
|----------------|------------|-------------|-------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                           |
| 31:22          | R/W        | 0x0         | SDM_CYCLE<br>SDM Cycle<br>SDM_CYCLE=SDM_FRE/CLK_SDM/2 |
| 21             | /          | /           | /                                                     |
| 20             | R/W        | 0x0         | SDM_DIRECTION<br>SDM direction<br>0: UP<br>1: DOWN    |
| 19             | /          | /           | /                                                     |
| 18             | R/W        | 0x0         | DITHER_EN<br>Dither Enable                            |
| 17             | R/W        | 0x0         | FRAC_EN<br>Fraction Enable                            |
| 16:0           | R/W        | 0x0         | FRAC_IN<br>Fraction In                                |

### 2.2.9.10 0x002C CPU\_L\_PLL Bias Register (Default Value: 0x0010\_0000)

| Offset: 0x002C |            |             | Register Name: CPU_L_PLL_BIAS_REG |
|----------------|------------|-------------|-----------------------------------|
| Bit            | Read/Write | Default/Hex | Description                       |
| 31:21          | /          | /           | /                                 |

| Offset: 0x002C |            |             | Register Name: CPU_L_PLL_BIAS_REG  |
|----------------|------------|-------------|------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                        |
| 20:16          | R/W        | 0x10        | PLL_CP<br>PLL Current Bias Control |
| 15:0           | /          | /           | /                                  |

#### 2.2.9.11 0x0030 CPU\_DSU\_PLL Bias Register (Default Value: 0x0010\_0000)

| Offset: 0x0030 |            |             | Register Name: CPU_DSU_PLL_BIAS_REG |
|----------------|------------|-------------|-------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                         |
| 31:21          | /          | /           | /                                   |
| 20:16          | R/W        | 0x10        | PLL_CP<br>PLL Current Bias Control  |
| 15:0           | /          | /           | /                                   |

#### 2.2.9.12 0x0034 CPU\_B\_PLL Bias Register (Default Value: 0x0010\_0000)

| Offset: 0x0034 |            |             | Register Name: CPU_B_PLL_BIAS_REG  |
|----------------|------------|-------------|------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                        |
| 31:21          | /          | /           | /                                  |
| 20:16          | R/W        | 0x10        | PLL_CP<br>PLL Current Bias Control |
| 15:0           | /          | /           | /                                  |

#### 2.2.9.13 0x003C CPU\_L\_PLL Tuning0 Register (Default Value: 0x0000\_0000)

| Offset: 0x003C |            |             | Register Name: CPU_L_PLL_TUN0_REG |
|----------------|------------|-------------|-----------------------------------|
| Bit            | Read/Write | Default/Hex | Description                       |
| 31:6           | /          | /           | /                                 |
| 5              | R/W        | 0x0         | PLL_LPF_SW                        |
| 4:2            | /          | /           | /                                 |
| 1:0            | R/W        | 0x0         | PLL_FF_SR                         |

#### 2.2.9.14 0x0040 CPU\_L\_PLL Tuning1 Register (Default Value: 0x0003\_2800)

| Offset: 0x0040 |            |             | Register Name: CPU_L_PLL_TUN1_REG |
|----------------|------------|-------------|-----------------------------------|
| Bit            | Read/Write | Default/Hex | Description                       |
| 31             | R/W        | 0x0         | PLL_SDM_EN                        |
| 30             | R/W        | 0x0         | PLL_FF_EN                         |
| 29             | R/W        | 0x0         | PLL_SS_EN                         |

| Offset: 0x0040 |            |             | Register Name: CPU_L_PLL_TUN1_REG |
|----------------|------------|-------------|-----------------------------------|
| Bit            | Read/Write | Default/Hex | Description                       |
| 28:20          | R/W        | 0x0         | PLL_SS_FRAC                       |
| 19:12          | R/W        | 0x32        | PLL_SS_INT                        |
| 11:0           | R/W        | 0x800       | PLL_FRAC                          |

#### 2.2.9.15 0x0044 CPU\_DSU\_PLL Tuning0 Register (Default Value: 0x0000\_0000)

| Offset: 0x0044 |            |             | Register Name: CPU_DSU_PLL_TUN0_REG |
|----------------|------------|-------------|-------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                         |
| 31:6           | /          | /           | /                                   |
| 5              | R/W        | 0x0         | PLL_LPF_SW                          |
| 4:2            | /          | /           | /                                   |
| 1:0            | R/W        | 0x0         | PLL_FF_SR                           |

#### 2.2.9.16 0x0048 CPU\_DSU\_PLL Tuning1 Register (Default Value: 0x0003\_2800)

| Offset: 0x0048 |            |             | Register Name: CPU_DSU_PLL_TUN1_REG |
|----------------|------------|-------------|-------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                         |
| 31             | R/W        | 0x0         | PLL_SDM_EN                          |
| 30             | R/W        | 0x0         | PLL_FF_EN.                          |
| 29             | R/W        | 0x0         | PLL_SS_EN                           |
| 28:20          | R/W        | 0x0         | PLL_SS_FRAC                         |
| 19:12          | R/W        | 0x32        | PLL_SS_INT                          |
| 11:0           | R/W        | 0x800       | PLL_FRAC                            |

#### 2.2.9.17 0x004C CPU\_B\_PLL Tuning0 Register (Default Value: 0x0000\_0000)

| Offset: 0x004C |            |             | Register Name: CPU_B_PLL_TUN0_REG |
|----------------|------------|-------------|-----------------------------------|
| Bit            | Read/Write | Default/Hex | Description                       |
| 31:6           | /          | /           | /                                 |
| 5              | R/W        | 0x0         | PLL_LPF_SW                        |
| 4:2            | /          | /           | /                                 |
| 1:0            | R/W        | 0x0         | PLL_FF_SR                         |

#### 2.2.9.18 0x0050 CPU\_B\_PLL Tuning1 Register (Default Value: 0x0003\_2800)

| Offset: 0x0050 |            |             | Register Name: CPU_B_PLL_TUN1_REG |
|----------------|------------|-------------|-----------------------------------|
| Bit            | Read/Write | Default/Hex | Description                       |
| 31             | R/W        | 0x0         | PLL_SDM_EN.                       |

| Offset: 0x0050 |            |             | Register Name: CPU_B_PLL_TUN1_REG |
|----------------|------------|-------------|-----------------------------------|
| Bit            | Read/Write | Default/Hex | Description                       |
| 30             | R/W        | 0x0         | PLL_FF_EN                         |
| 29             | R/W        | 0x0         | PLL_SS_EN                         |
| 28:20          | R/W        | 0x0         | PLL_SS_FRAC                       |
| 19:12          | R/W        | 0x32        | PLL_SS_INT                        |
| 11:0           | R/W        | 0x800       | PLL_FRAC                          |

#### 2.2.9.19 0x0054 CPU\_L\_PLL SSC Register (Default Value: 0x4CCC\_A000)

| Offset: 0x0054 |            |             | Register Name: CPU_L_PLL_SSC_REG                                                                                                                                                                                                                                                                                                                                                                                     |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                          |
| 31             | R/W        | 0x0         | PLL_SSC_MODE<br>0: Normal Mode<br>1:Continuously Frequency Scale                                                                                                                                                                                                                                                                                                                                                     |
| 30             | R/W        | 0x1         | PLL_SSC_RSTN<br>SSC RSTN Bake Up                                                                                                                                                                                                                                                                                                                                                                                     |
| 29             | R/W        | 0x0         | PLL_SSC_CLK_SEL<br>SSC CLK Selection<br>0: REF_CLK<br>1: PLL_CLK_SDM                                                                                                                                                                                                                                                                                                                                                 |
| 28:12          | R/W        | 0xCCCA      | PLL_SSC<br>SSC amplitude must be an integer multiple of 2^step.<br>spread spectrum amplitude = (SSC amplitude + 2^step)<br>*24/(2^17), unit: MHz.                                                                                                                                                                                                                                                                    |
| 11:7           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 6:4            | R/W        | 0x0         | PLL_PHASE_COMPENSATE<br>The value of bit[6:4] is based on 24M clock, then the default<br>PLL phase compensate is (3/24000000)s.                                                                                                                                                                                                                                                                                      |
| 3:0            | R/W        | 0x0         | PLL_SSC_STEP<br>0000:0.00439MHz/us (576/2^17)<br>0001:0.00879MHz/us (576/2^16)<br>0010:0.01758MHz/us (576/2^15)<br>0011:0.03516MHz/us (576/2^14)<br>0100:0.07031MHz/us (576/2^13)<br>0101:0.14062MHz/us (576/2^12)<br>0110:0.28125MHz/us (576/2^11)<br>0111:0.56250MHz/us (576/2^10)<br>1000:1.12500MHz/us (576/2^9)<br>1001:2.25000MHz/us (576/2^8)<br>1010:4.50000MHz/us (576/2^7)<br>1011:9.00000MHz/us (576/2^6) |

| Offset: 0x0054 |            |             | Register Name: CPU_L_PLL_SSC_REG |
|----------------|------------|-------------|----------------------------------|
| Bit            | Read/Write | Default/Hex | Description                      |
|                |            |             | Others:0.00439MHz/us (576/2^17)  |

#### 2.2.9.20 0x0058 CPU\_DSU\_PLL SSC Register (Default Value: 0x4CCC\_A000)

| Offset: 0x0058 |            |             | Register Name: CPU_DSU_PLL_SSC_REG                                                                                                                                                                                                                                                                                                                                                                                                                      |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 31             | R/W        | 0x0         | PLL_SSC_MODE<br>0: Normal Mode<br>1:Continuously Frequency Scale                                                                                                                                                                                                                                                                                                                                                                                        |
| 30             | R/W        | 0x1         | PLL_SSC_RSTN<br>SSC RSTN Bake Up                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 29             | R/W        | 0x0         | PLL_SSC_CLK_SEL<br>SSC CLK Selection<br>0: REF_CLK<br>1: PLL_CLK_SDM                                                                                                                                                                                                                                                                                                                                                                                    |
| 28:12          | R/W        | 0xCCCA      | PLL_SSC<br>SSC amplitude must be an integer multiple of 2^step.<br>spread spectrum amplitude = (SSC amplitude + 2^step)<br>*24/(2^17), unit: MHz.                                                                                                                                                                                                                                                                                                       |
| 11:7           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 6:4            | R/W        | 0x0         | PLL_PHASE_COMPENSATE<br>The value of bit[6:4] is based on 24M clock, then the default<br>PLL phase compensate is (3/24000000)s.                                                                                                                                                                                                                                                                                                                         |
| 3:0            | R/W        | 0x0         | PLL_SSC_STEP<br>0000:0.00439MHz/us (576/2^17)<br>0001:0.00879MHz/us (576/2^16)<br>0010:0.01758MHz/us (576/2^15)<br>0011:0.03516MHz/us (576/2^14)<br>0100:0.07031MHz/us (576/2^13)<br>0101:0.14062MHz/us (576/2^12)<br>0110:0.28125MHz/us (576/2^11)<br>0111:0.56250MHz/us (576/2^10)<br>1000:1.12500MHz/us (576/2^9)<br>1001:2.25000MHz/us (576/2^8)<br>1010:4.50000MHz/us (576/2^7)<br>1011:9.00000MHz/us (576/2^6)<br>Others:0.00439MHz/us (576/2^17) |

### 2.2.9.21 0x005C CPU\_B\_PLL SSC Register (Default Value: 0x4CCC\_A000)

| Offset: 0x005C |            |             | Register Name: CPU_B_PLL_SSC_REG                                                                                                                                                                                                                                                                                                                                                                                                                        |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 31             | R/W        | 0x0         | PLL_SSC_MODE<br>0: Normal Mode<br>1: Continuously Frequency Scale                                                                                                                                                                                                                                                                                                                                                                                       |
| 30             | R/W        | 0x1         | PLL_SSC_RSTN<br>SSC RSTN Bake Up                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 29             | R/W        | 0x0         | PLL_SSC_CLK_SEL<br>SSC CLK Selection<br>0: REF_CLK<br>1: PLL_CLK_SDM                                                                                                                                                                                                                                                                                                                                                                                    |
| 28:12          | R/W        | 0xCCCA      | PLL_SSC<br>SSC amplitude must be an integer multiple of 2^step.<br>spread spectrum amplitude = (SSC amplitude + 2^step)<br>*24/(2^17), unit: MHz.                                                                                                                                                                                                                                                                                                       |
| 11:7           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 6:4            | R/W        | 0x0         | PLL_PHASE_COMPENSATE<br>The value of bit[6:4] is based on 24M clock, then the default<br>PLL phase compensate is (3/24000000)s.                                                                                                                                                                                                                                                                                                                         |
| 3:0            | R/W        | 0x0         | PLL_SSC_STEP<br>0000:0.00439MHz/us (576/2^17)<br>0001:0.00879MHz/us (576/2^16)<br>0010:0.01758MHz/us (576/2^15)<br>0011:0.03516MHz/us (576/2^14)<br>0100:0.07031MHz/us (576/2^13)<br>0101:0.14062MHz/us (576/2^12)<br>0110:0.28125MHz/us (576/2^11)<br>0111:0.56250MHz/us (576/2^10)<br>1000:1.12500MHz/us (576/2^9)<br>1001:2.25000MHz/us (576/2^8)<br>1010:4.50000MHz/us (576/2^7)<br>1011:9.00000MHz/us (576/2^6)<br>Others:0.00439MHz/us (576/2^17) |

### 2.2.9.22 0x0060 CPUA Clock Register (Default Value: 0x0000\_0305)

| Offset: 0x0060 |            |             | Register Name: CPUA_CLK_REG |
|----------------|------------|-------------|-----------------------------|
| Bit            | Read/Write | Default/Hex | Description                 |
| 31:27          | /          | /           | /                           |

| Offset: 0x0060 |            |             | Register Name: CPUA_CLK_REG                                                                                                                                                                                                                                  |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                  |
| 26:24          | R/W        | 0x0         | <p>CPUA_CLK_SEL<br/>Clock Source Selection<br/>000: HOSC<br/>001: CLK32K<br/>010: CLK16M_RC<br/>011: CPU1PLL/P<br/>100: PERIO_600M<br/>101: CPU0PLL<br/>CPUA_CLK = Clock Source<br/>The clock MUX supports glitch-free switch and dynamic configuration.</p> |
| 23:18          | /          | /           | /                                                                                                                                                                                                                                                            |
| 17:16          | R/W        | 0x0         | <p>CPU_L_PLL_OUT_EXT_DIVP<br/>Factor P<br/>00: 1<br/>01: 2<br/>10: 4<br/>11: \\\<br/>When the output clock is less than 288 MHz, it can divide P to get the required clock frequency.</p>                                                                    |
| 15:10          | /          | /           | /                                                                                                                                                                                                                                                            |
| 9:8            | R/W        | 0x3         | <p>CPU_APB_DIV_CFG.<br/>Factor N.<br/>(N = FACTOR_N +1)<br/>FACTOR_N is 1 or 3.<br/>The clock division is no-burr switch, and supports dynamic configuration.</p>                                                                                            |
| 7:4            | /          | /           | /                                                                                                                                                                                                                                                            |
| 3:2            | R/W        | 0x1         | <p>CPU_PERI_DIV_CFG.<br/>Factor M1:(M= FACTOR_M1 +1)<br/>FACTOR_M1 is 0, 1, or 3.<br/>The clock division is no-burr switch, and supports dynamic configuration.</p>                                                                                          |
| 1:0            | R/W        | 0x1         | <p>CPU_AXI_DIV_CFG.<br/>Factor M:(M= FACTOR_M +1)<br/>FACTOR_M is from 1 to 3<br/>The clock division is no-burr switch, and supports dynamic configuration.</p>                                                                                              |

## 2.2.9.23 0x0064 CPUB Clock Register (Default Value: 0x0000\_0305)

| Offset: 0x0064 |            |             | Register Name: CPUB_CLK_REG                                                                                                                                                                                                                                             |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                             |
| 31:27          | /          | /           | /                                                                                                                                                                                                                                                                       |
| 26:24          | R/W        | 0x0         | <p>CPUB_CLK_SEL.<br/>Clock Source Selection.</p> <p>000: HOSC<br/>001: CLK32K<br/>010: CLK16M_RC<br/>011: CPU3PLL/P<br/>100: PERIO_600M<br/>101: CPU0PLL</p> <p>CPU_CLK = Clock Source.</p> <p>The clock MUX supports glitch-free switch and dynamic configuration.</p> |
| 23:18          | /          | /           | /                                                                                                                                                                                                                                                                       |
| 17:16          | R/W        | 0x0         | <p>CPU_B_PLL_OUT_EXT_DIVP.<br/>Factor P</p> <p>00: 1<br/>01: 2<br/>10: 4<br/>11: \</p> <p>When the output clock is less than 288 MHz, it can divide P to get the required clock frequency.</p>                                                                          |
| 15:0           | /          | /           | /                                                                                                                                                                                                                                                                       |

## 2.2.9.24 0x0068 CPU Gating Configuration Register (Default Value: 0x0000\_0007)

| Offset: 0x0068 |            |             | Register Name: CPU_GATING_REG:                                                                                        |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                           |
| 31:16          | W          | 0x0         | <p>CPU_GATING_FIELD<br/>CPU Gating Field</p> <p>If CPU_GATING_FIELD==16' h16AA, the bit [15:0] can be configured.</p> |
| 15:4           | /          | /           | /                                                                                                                     |
| 3              | R/W        | 0x0         | <p>DSU_PPU_SW_GATE_EN<br/>DSU PPU Control Enable</p> <p>0: Disable<br/>1: Enable</p>                                  |
| 2              | R/W        | 0x1         | DSU_CLK_GATING<br>Gating Clock                                                                                        |

| Offset: 0x0068 |            |             | Register Name: CPU_GATING_REG:                                       |
|----------------|------------|-------------|----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                          |
|                |            |             | 0: Clock is OFF<br>1: Clock is ON                                    |
| 1              | R/W        | 0x1         | CPUB_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON |
| 0              | R/W        | 0x1         | CPUA_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON |

#### 2.2.9.25 0x006C DSU Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x006C |            |             | Register Name: DSU_CLK_REG                                                                                                                                                                                                                                                                                                             |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                            |
| 31:27          | /          | /           | /                                                                                                                                                                                                                                                                                                                                      |
| 26:24          | R/W        | 0x0         | DSU_CLK_SEL<br>Clock Source Selection<br>000: HOSC<br>001: CLK32K<br>010: CLK16M_RC<br>011: CPU2PLL/P<br>100: PERI0PLL2X<br>101: PERI0_600M<br>DSU_CLK = Clock Source.<br>CPU_AXI Clock = DSU_CLK/M.<br>CPU_APB Clock= DSU_CLK/N.<br>CPU_GIC Clock=DSU_CLK/M1.<br>The clock MUX supports glitch-free switch and dynamic configuration. |
| 23:18          | /          | /           | /                                                                                                                                                                                                                                                                                                                                      |
| 17:16          | R/W        | 0x0         | CPU_DSU_PLL_OUT_EXT_DIVP<br>Factor P<br>00: 1<br>01: 2<br>10: 4<br>11: \<br>When the output clock is less than 288 MHz, it can divide P to get the required clock frequency.                                                                                                                                                           |
| 15:0           | /          | /           | /                                                                                                                                                                                                                                                                                                                                      |

## 2.2.9.26 0x0070 PLL Test Clock Selection Register (Default Value: 0x0000\_0300)

| Offset: 0x0070 |            |             | Register Name: PLL_TEST_CLK_SEL                         |
|----------------|------------|-------------|---------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                             |
| 31:27          | /          | /           | /                                                       |
| 9:8            | R/W        | 0x3         | PLL_CFG_CLK_DIV<br>PLL Config Clock Div                 |
| 7:1            | /          | /           | /                                                       |
| 0              | R/W        | 0x0         | CLK_SEL<br>Clock Selection<br>0: COREPLLA<br>1: DSU_CLK |



## 2.3 RISC-V System (RISCV)

### 2.3.1 Overview

The RISC-V system includes RISC IP core and related peripheral devices (AHB\_Decoder, AHB2APB, RISCV\_CFG, RISC\_TIMESTAMP, and so on), which is able to be interconnected to MCU system by MCU AHB Matrix.

The RISC-V system has the following features:

- Configurable start address via software
- Combined with PPU module, supporting standby in low-power mode and wake-up through external interrupts
- Separate TIMERSTAMP supports timing immediately after reset is released
- Separate watchdog supports to reset the SoC system when the RISC-V system malfunctions
- Separate message box supports communicating with other modules
- Supports separate PMU check module

### 2.3.2 Block Diagram

The following figure shows the block diagram of RISC-V system.

Figure 2-2 RISC-V System Block Diagram



### 2.3.3 Register List

| Module Name | Base Address |
|-------------|--------------|
| RISCV_CFG   | 0x0713_0000  |

| Register Name          | Offset | Description                            |
|------------------------|--------|----------------------------------------|
| RF1P_CFG_REG           | 0x0010 | RF1P Configuration Register            |
| TS_TMODE_SEL_REG       | 0x0040 | Timestamp Test Mode Selection Register |
| RISCV_STA_ADD_REG      | 0x0204 | RISC-V Start Address Register          |
| RISCV_WAKEUP_EN_REG    | 0x0220 | RISC-V Wakeup Enable Register          |
| RISCV_WAKEUP_MASK0_REG | 0x0224 | RISC-V Wakeup Mask0 Register           |
| RISCV_WAKEUP_MASK1_REG | 0x0228 | RISC-V Wakeup Mask1 Register           |
| RISCV_WAKEUP_MASK2_REG | 0x022C | RISC-V Wakeup Mask2 Register           |
| RISCV_WAKEUP_MASK3_REG | 0x0230 | RISC-V Wakeup Mask3 Register           |
| RISCV_WORK_MODE_REG    | 0x0248 | RISC-V Work Mode Register              |

### 2.3.4 Register Description

#### 2.3.4.1 0x0010 RF1P Configuration Register (Default Value: 0x0000\_0400)

| Offset: 0x0010 |            |             | Register Name: RF1P_CFG_REG    |
|----------------|------------|-------------|--------------------------------|
| Bit            | Read/Write | Default/Hex | Description                    |
| 31:16          | /          | /           | /                              |
| 15:0           | R/W        | 0x400       | RF1P_CFG<br>RF1P Configuration |

#### 2.3.4.2 0x0040 Timestamp Test Mode Selection Register (Default Value: 0x0000\_0000)

| Offset: 0x0040 |            |             | Register Name: TS_TMODE_SEL_REG                                                                                                                                       |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                           |
| 31:2           | /          | /           | /                                                                                                                                                                     |
| 1              | R/W        | 0x0         | RISCV_TS_TEST_MODE_EN<br>RISCV Timestamp Test Mode Enable<br>0: Normal Mode<br>1: Test Mode<br>In Test Mode, this Counter Low/Hi registers will count simultaneously. |
| 0              | /          | /           | /                                                                                                                                                                     |

#### 2.3.4.3 0x0204 RISCV Start Address Register (Default Value: 0x3FFC\_0000)

this register is the running PC address after RISCV releases reset. Before releasing reset, this register should be configured. This register does support dynamic configuration.

| Offset: 0x0204 |            |             | Register Name: RISCV_STA_ADD0_REG                                             |
|----------------|------------|-------------|-------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                   |
| 31:0           | R/W        | 0x3FFC0000  | STA_ADD<br>Start Address<br>The bit 0 is fixed as 0 and could not be written. |

#### 2.3.4.4 0x0220 RISCV Wakeup Enable Register (Default Value: 0x0000\_0000)

| Offset: 0x0220 |            |             | Register Name: RISCV_WAKEUP_EN_REG                                                               |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                      |
| 31:1           | /          | /           | /                                                                                                |
| 0              | R/W        | 0x0         | WP_EN<br>Wakeup Enable<br>To wake up the enable bit of RISC-V, when RISC-V is in low power mode. |

#### 2.3.4.5 0x0224 RISCV Wakeup Mask0 Register (Default Value: 0x0000\_0000)

The 0x0224 to 0x0230 registers corresponds to the wakeup enable bits of 128 interrupts. These wakeup enable bits are disabled by default. When some interrupt needs to be waken-up, the corresponding bit needs to be set to 1. For detailed interrupt sources, please refer to section 2.8 Core-Local Interrupt Controller (CLIC)

| Offset: 0x0224 |            |             | Register Name: RISCV_WAKEUP_MASK0_REG |
|----------------|------------|-------------|---------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                           |
| 31:0           | R/W        | 0x00000000  | WP_MASK0<br>Wakeup Mask0              |

#### 2.3.4.6 0x0228 RISCV Wakeup Mask1 Register (Default Value: 0x0000\_0000)

| Offset: 0x0228 |            |             | Register Name: RISCV_WAKEUP_MASK1_REG |
|----------------|------------|-------------|---------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                           |
| 31:0           | R/W        | 0x00000000  | WP_MASK1<br>Wakeup Mask1              |

#### 2.3.4.7 0x022C RISCV Wakeup Mask2 Register (Default Value: 0x0000\_0000)

| Offset: 0x022C |            |             | Register Name: RISCV_WAKEUP_MASK2_REG |
|----------------|------------|-------------|---------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                           |
| 31:0           | R/W        | 0x00000000  | WP_MASK2<br>Wakeup Mask2              |

#### 2.3.4.8 0x00230 RISCV Wakeup Mask3 Register (Default Value: 0x0000\_0000)

| Offset: 0x00230 |            |             | Register Name: RISCV_WAKEUP_MASK3_REG |
|-----------------|------------|-------------|---------------------------------------|
| Bit             | Read/Write | Default/Hex | Description                           |
| 31:0            | R/W        | 0x00000000  | WP_MASK3<br>Wakeup Mask3              |

#### 2.3.4.9 0x0248 RISCV Work Mode Register (Default Value: 0x0000\_0003)

| Offset: 0x0248 |            |             | Register Name: RISCV_WORK_MODE_REG                                                                                                                                                                  |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                         |
| 31:4           | /          | /           | /                                                                                                                                                                                                   |
| 3              | R          | 0x0         | LOCKUP_STA<br>Lockup Status<br>0: Not Lockup<br>1: Lockup<br>If CPU has a lockup, CPU will stop accessing data and fetching, and clear the pipeline. Reset processor unit and debug unit to unlock. |
| 2              | R          | 0x0         | DM_STA<br>Debug Mode Status<br>0: Normal Mode<br>1: Debug Mode                                                                                                                                      |
| 1:0            | R          | 0x3         | LP_STA<br>Low Power Status<br>00: Deep Sleep Low Power Mode<br>01: Light Sleep Low Power Mode<br>10: Reserved<br>11: Normal Mode                                                                    |

## 2.4 BROM System

### 2.4.1 Overview

The system has several ways to boot. It has an integrated on-chip Boot ROM (BROM) that is considered the primary program-loader. On the startup process, the A523 starts to fetch the first instruction from address 0x0, where is the BROM located at.

The BROM system is divided into two parts: the firmware exchange launch (FEL) module and the Medium Boot module. FEL is responsible for writing the external data to the local NVM, and Medium Boot is responsible for loading an effective and legitimate BOOT0 from NVM and running.

The BROM system includes the following features:

- Supports CPU0 boot process
- Supports mandatory upgrade process through USB and SD card
- Supports GPADC0 pin and eFuse module to select the boot media type
- Supports normal booting and secure booting
- Secure BROM loads only certified firmware
- Ensures that the secure boot is in a trusted environment

### 2.4.2 Functional Description

#### 2.4.2.1 Selecting the Boot Medium

The BROM system supports the following boot media:

- SD Card
- eMMC
- RAW NAND Flash
- SPI NOR Flash (Quad Mode and Single Mode)
- SPI NAND Flash

There are two ways to select the boot medium: GPADC Pin Select and eFuse Select. The BROM will read the state of BOOT\_MODE first, and then select the boot medium according to the state of BOOT\_MODE. The BOOT\_MODE is the BROM\_Config in the eFuse mapping.

The following table shows the BOOT\_MODE setting:

Table 2-5 BOOT\_MODE Setting

| BOOT_MODE[0] | Boot Select type |
|--------------|------------------|
| 0            | GPADC Selection  |
| 1            | eFuse Selection  |

**NOTE**

The BOOT\_MODE BIT is bit [0] of the eFuse register 0x03006210.

**GPADC Boot Selection**

If the state of the BOOT\_MODE is 0, choose the GPADC Boot Selection.

If BROM failed to boot from the selected medium, it will try other media with the following priority:

**EMMC\_USR -> EMMC\_BOOT -> SLC\_NAND -> MLC\_NAND -> SPI\_NOR -> SPI\_NAND**

And the medium selected by GPADC will be skipped.

For example, when BROM failed to boot from SPI NOR, it will try other media with the following priority:

**SPI NOR (selected by GPADC) -> EMMC\_USR -> EMMC\_BOOT -> SLC\_NAND -> MLC\_NAND -> SPI\_NOR (try at first, skipped) -> SPI\_NAND**

The following table shows GPADC Boot Select setting.

**Table 2-6 GPADC Boot Select Setting**

| KEY_VALUE    | Boot Select type                                      |
|--------------|-------------------------------------------------------|
| 0x00-0xB6    | SD Card->MLC NAND->SLC NAND->try (except SPI in PJ)   |
| 0xB7-0x22B   | SD Card->SLC NAND->MLC NAND->try (except SPI in PJ)   |
| 0x22C-0x3AF  | SD Card->EMMC_USER->EMMC_BOOT->try (except SPI in PJ) |
| 0x3B0-0x57B  | SD Card->EMMC_BOOT->EMMC_USER->try (except SPI in PJ) |
| 0x57C-0x73C  | SD Card->SPI NOR->try (except SPI in PJ)              |
| 0x73D-0x8CC  | SD Card->SPI NAND->try (except SPI in PJ)             |
| 0x8CD-0xB49  | SD Card->SPI NOR in PJ->try                           |
| 0xB4A-0xE7C  | SD Card->SPI NAND in PJ->try                          |
| 0x8CD-0xFFFF | Reserved                                              |

**NOTE**

When trying SPI NOR, BROM try 4 wire mode first, then 1 wire mode.

**eFuse Boot Selection**

If the state of the BOOT\_MODE is 1, choose the eFuse Boot Selection.

The eFuse\_Boot\_Select\_Cfg is divided into 3 groups and each group is 3-bit. The following table shows the groups of eFuse\_Boot\_Select.

**Table 2-7 Groups of eFuse\_Boot\_Select**

| eFuse_Boot_Select_Cfg [11:0] | Description |
|------------------------------|-------------|
|------------------------------|-------------|

| eFuse_Boot_Select_Cfg [11:0] | Description         |
|------------------------------|---------------------|
| eFuse_Boot_Select[3:0]       | eFuse_Boot_Select_1 |
| eFuse_Boot_Select[7:4]       | eFuse_Boot_Select_2 |
| eFuse_Boot_Select[11:8]      | eFuse_Boot_Select_3 |

These three groups take effect with the following priority:

**eFuse\_Boot\_Select\_1 -> eFuse\_Boot\_Select\_2 -> eFuse\_Boot\_Select\_3**

For example, eFuse\_Boot\_Select\_2 will not take effect unless eFuse\_Boot\_Select\_1 is set as 0b1111(skip), eFuse\_Boot\_Select\_3 will not take effect unless eFuse\_Boot\_Select\_2 is set as 0b1111(skip), etc. If all three groups are set to 0b1111, no other groups can be used for boot select, BROM assume “try” is selected.

In the Try mode, the BROM follows the order below to select the boot medium:

**SD Card -> eMMC -> NAND FLASH -> SPI NOR -> SPI NAND**

The following table shows the boot medium priority for the different values of eFuse\_Boot\_Select\_n, where n = [4:1].

**Table 2-8 eFuse Boot Select Setting**

| eFuse_Boot_Select_n | Boot media                                                                                                                                        |
|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| 0000                | Try (except SPI in PJ)                                                                                                                            |
| 0001                | SLC NAND -> MLC NAND                                                                                                                              |
| 0010                | EMMC_USER -> EMMC_BOOT                                                                                                                            |
| 0011                | SPI NOR                                                                                                                                           |
| 0100                | SPI NAND                                                                                                                                          |
| 0101                | MLC NAND -> SLC NAND                                                                                                                              |
| 0110                | MMC_BOOT -> EMMC_USER                                                                                                                             |
| 1011                | SPI NOR in PJ                                                                                                                                     |
| 1100                | SPI NAND in PJ                                                                                                                                    |
| 1111                | When n is 1 or 2:<br>The boot medium is decided by the value of eFuse_Boot_Select_(n + 1).<br>When n is 4:<br>Select the boot medium in Try mode. |



#### NOTE

The status of the eFuse boot select pin is the bit [11:0] of the eFuse register 0x03006212.

#### 2.4.2.2 Selecting the Boot Mode

For SoCs that have implemented and enabled the ARM TrustZone technology, there are two boot modes: Normal BROM Mode and Secure BROM Mode.

Secure BROM Mode is designed to protect against attackers modifying the code or data areas in the programmable memory.

During the startup process, the BROM will select the boot mode according to the value of the Secure Enable bit. If the value of Secure Enable bit is 0, the system will boot in Normal BROM Mode. Otherwise, it will boot in Secure BROM Mode.



#### NOTE

The System on Chip (SoC) supports the ARM TrustZone technology. If the Secure Enable Bit is enabled, the BROM will be safely booted based on this ARM TrustZone technology.

#### Normal BROM Mode

In Normal BROM Mode, the system boot starts from CPU0, and then the BROM will read the state of the FEL pin. If the FEL pin is high, the system will jump to the fast boot process. If it is low, the system will jump to the mandatory update process.

The following figure shows the boot process in Normal BROM Mode.

**Figure 2-3 Boot Process in Normal BROM Mode**



## Secure BROM Mode

The process of selecting the boot medium in Secure Boot Mode is the same as that in Normal Boot Mode.

In Secure Boot Mode, after the boot medium is selected, the system additionally runs the Security Boot software to authenticate the Sboot bin file.

The following figure shows the authentication process.

**Figure 2-4 Authentication Process in Secure BROM Mode**



## Secure BROM Requirements

The Secure Boot has the following some requirement:

- Supports X509 certificate

The certificate is used to check whether the Security Boot software is modified or replaced. Before running the Security Boot software, the system checks the integrity of the certificate make sure the software has not been modified or replaced.

- Supports cryptographic algorithms

- AES-128
- SHA-256
- RSA-2048
- AES, DES

The system uses the Crypto Engine (CE) hardware module to accelerate the speed of encryption and decryption. The standard cryptography ensures the reliability of the firmware images. The reliable firmware image ensures that the system security state can be as expected.

- Support OTP/eFuse

### 2.4.2.3 Mandatory Upgrade Process

If the FEL pin is detected to pull low, the system will jump to the mandatory upgrade process. The following figure shows the mandatory upgrade process.

**Figure 2-5 Mandatory Upgrade Process**



#### NOTE

The FEL address of the Normal BROM is 0x20.

## FEL Process

When the system enters mandatory upgrade process, it will jump to the FEL process.

The following figure shows the FEL upgrade process.

Figure 2-6 USB FEL Process



#### 2.4.2.4 Fast Boot Process

If the value of the [Fast Boot register](#) (0x07090120) in RTC module is not zero, the system will enter the fast boot process. The following table shows the boot medium priority for different values of the Fast Boot register.

Table 2-9 Fast Boot Select Setting

| Reg_bit[31:28] | Boot Select type                                 |
|----------------|--------------------------------------------------|
| 1              | SD Card->MLC NAND -> SLC NAND -> TRY             |
| 2              | SD Card->EMMC_USER -> EMMC_BOOT -> TRY           |
| 3              | SD Card->SPI NOR(1 wire)-> SPI NOR(4 wire)-> TRY |
| 4              | SD Card->SPI NAND -> TRY                         |
| 5              | SD Card->EMMC_BOOT -> EMMC_USER -> TRY           |
| 6              | SD Card->SLC NAND -> MLC NAND -> TRY             |
| 7              | Reserved                                         |
| 8              | SD Card->SPI NOR(4 wire)-> SPI NOR(1 wire)-> TRY |
| 10             | SD Card->SPI NOR(4 wire) in PJ -> TRY            |
| 11             | SD Card->SPI NAND in PJ-> TRY                    |



#### NOTE

- The Fast Boot register bit [27:0] is used record the media information.
- Unused value like 7 regarded as "TRY".

## 2.5 Clock Controller Unit (CCU)

### 2.5.1 Overview

The clock controller unit (CCU) controls the PLL configurations and most of the clock generation, division, distribution, synchronization, and gating. The input signals of the CCU include the external clock for the reference frequency (24 MHz). The outputs from the CCU are mostly clocks to other blocks in the system.

The CCU includes the following features:

- 10 PLLs
- Bus source and divisions
- Clock output control
- Configuring modules clock
- Bus clock gating
- Bus software reset



#### NOTE

- There are 15 PLLs in A523. 10 PLLs in CCU, 4 PLLs in CPUX system, and 1 PLL in MCU\_PRCM.
- CCU describes module clocks in CPUX domain excluding the clock of CPUX system.
- For clock description of CPUX system, please refer to section 2.2.3.2 CPU PLL Distribution and Clock Sources.
- For module clocks in CPUS domain, please refer to section 2.11 Power Reset Clock Management (PRCM).

## 2.5.2 Block Diagram

The following figure shows the functional block diagram of the CCU.

**Figure 2-7 CCU Block Diagram**



## 2.5.3 Functional Description

### 2.5.3.1 Typical Application

**Figure 2-8 CCU Typical Application Diagram**



CCU outputs bus clock, bus reset, function clock, and function reset to each IP module.

It is needed to enable the bus clock gating signal before using the bus clock. For some subsystems, CCU outputs special bus clock which has been added clock gating. When using the special bus clock, you also need to enable the bus clock gating signal.

The IP reset is from the synchronous release of the input reset signal. To ensure the implement of synchronous release in every module, you need to release the reset signal before enabling the clock gating signal of the function clock.

### 2.5.3.2 PLL Distribution

The following figure shows the block diagram of the PLL distribution.

**Figure 2-9 PLL Distribution**



### 2.5.3.3 PLL Features

The following table shows the PLL features.

**Table 2-10 PLL Features**

| PLL     | Stable Operating Frequency | Actual Operating Frequency | Spread Spectrum | Linear FM | Pk-Pk   | Lock Time |
|---------|----------------------------|----------------------------|-----------------|-----------|---------|-----------|
| PLL_DDR | 1.26 GHz~2.52 GHz          | < 2.5 GHz                  | Yes             | No        | < 200ps | 500us     |

| PLL        | Stable Operating Frequency | Actual Operating Frequency                                            | Spread Spectrum | Linear FM | Pk-Pk   | Lock Time |
|------------|----------------------------|-----------------------------------------------------------------------|-----------------|-----------|---------|-----------|
| PLL_GPU    | 1.26 GHz~2.52 GHz          | < 1.5 GHz                                                             | Yes             | No        | < 200ps | 500us     |
| PLL_PERI0  | 1.26 GHz~2.52 GHz          | 2x: 1.2 GHz<br>3x: 800 MHz<br>5x: 480 MHz                             | Yes             | No        | < 200ps | 500us     |
| PLL_PERI1  | 1.26 GHz~2.52 GHz          | 2x: 1.248 GHz/1.2 GHz<br>3x: 832 MHz/800 MHz<br>5x: 499.2 MHz/480 MHz | Yes             | No        | < 200ps | 500us     |
| PLL_VE     | 1.26 GHz~2.52 GHz          | < 1.5 GHz                                                             | Yes             | No        | < 200ps | 500us     |
| PLL_AUDIO0 | 1.26 GHz~2.52 GHz          | 1x: 22.5792 MHz<br>4x: 22.5792*4 MHz                                  | Yes             | No        | < 200ps | 500us     |
| PLL_VIDEO  | 1.26 GHz~2.52 GHz          | 3x: 792 MHz<br>4x: 1188 MHz                                           | Yes             | No        | < 200ps | 500us     |

## 2.5.4 Programming Guidelines



### NOTE

It is not suggested to enable or disable the PLLs frequently during usage. Because the enabling and disabling of PLL will cause a mutual interference between PLLs, which will affect system stability. When the clock is not required, it is recommended to configure the PLL\_OUTPUT\_GATE bit of PLL control register as 0 instead of writing 0 to the enable bit.

### 2.5.4.1 Enabling the PLL

Follow the steps below to enable the PLL:

- Step 1** Configure the N, M, and P factors of the PLL control register.
- Step 2** Write 1 to the PLL\_EN bit (bit [31]) and the PLL\_LDO\_EN bit (bit [30]) of the PLL control register, write 0 to the PLL\_OUTPUT\_GATE bit (bit [27]) of the PLL control register.
- Step 3** Write 1 to the LOCK\_ENABLE bit (bit [29]) of the PLL control register.
- Step 4** Wait for the status of the Lock to change to 1.
- Step 5** Delay 20 us.
- Step 6** Write the PLL\_OUTPUT\_GATE bit (bit [27]) of the PLL control register to 1 and then the PLL will be available.

#### 2.5.4.2 Configuring the Frequency of General PLLs

- Step 1** Make sure the PLL is enabled. If not, refer to section 2.5.4.1 Enabling the PLL to enable the PLL.
- Step 2** Configure the PLL\_OUTPUT\_GATE bit (bit [27]) of the PLL control register as 0 to disable the output gate of the PLL. Because, general PLLs are unavailable in the process of frequency modulation.
- Step 3** Configure the N and M factors. (It is not suggested to configure M1 factor)
- Step 4** Write 0 and then write 1 to the LOCK\_ENABLE bit (bit [29]) of the PLL control register.
- Step 5** Wait for the LOCK bit (bit [28]) of the PLL control register to 1.
- Step 6** Configure PLL\_OUTPUT\_GATE bit (bit [27]) of the PLL control register to 1.

#### 2.5.4.3 Configuring the Frequency of PLL\_AUDIO0

The frequency configuration formula of PLL\_AUDIO0:

$$\text{PLL\_AUDIO0} = 24 \text{ MHz} * N / M0 / M1 / P$$

PLL\_AUDIO0 does not support dynamic adjustment because changing any parameter of N, M0, M1, and P will affect the normal work of PLL, and the PLL will need to be relocked.

Generally, PLL\_AUDIO0 only needs two frequency points: 24.576\*4 MHz or 22.5792\*4 MHz. For these two frequencies, there are usually special recommended matching factors. To implement the desired frequency point of PLL\_AUDIO0, you need to use the decimal frequency-division function, so follow the steps below:

- Step 1** Configure the N, M0, M1 and P factors.
- Step 2** Write 1 to the PLL\_SDM\_EN bit (bit [24]) of [PLL\\_AUDIO0\\_CTRL](#) register.
- Step 3** Configure [PLL\\_AUDIO0\\_PATO\\_CTRL](#) register to enable the digital spread spectrum.
- Step 4** Write 0 and then write 1 to the LOCK ENABLE bit (bit [29]) of [PLL\\_AUDIO0\\_CTRL](#) register.
- Step 5** Write 1 to the LOCK bit (bit [28]) of [PLL\\_AUDIO0\\_CTRL](#) register.



#### NOTE

- When the P factor of PLL\_AUDIO0 is an odd number, the clock output is an unequal-duty-cycle signal.
- A523 includes PLL\_AUDIO0 and PLL\_AUDIO1. For detailed description of PLL\_AUDIO1, please refer to section 2.11 Power Reset Clock Management (PRCM).

#### 2.5.4.4 Disabling the PLL

Follow the steps below to disable the PLL:

- Step 1** Write 0 to the PLL\_EN bit (bit [31]) and the PLL\_LDO\_EN bit (bit [30]) of the PLL control register.
- Step 2** Write 0 to the LOCK\_ENABLE bit (bit [29]) of the PLL control register.

#### 2.5.4.5 Implementing Spread Spectrum

The spread spectrum technology is to convert a narrowband signal into a wideband signal. It helps to reduce the effect of electromagnetic interference (EMI) associated with the fundamental frequency of the signal.

For the general PLL frequency, the calculation formula is as follows:

$$f = \frac{N+X}{P \cdot (M_0+1) \cdot (M_1+1)} \cdot 24MHz, 0 < X < 1$$

Where,

P is the frequency division factor of module or PLL;

M0 is the post-frequency division factor of PLL;

M1 is the pre-frequency division factor of PLL;

N is the frequency doubling factor of PLL;

X is the amplitude coefficient of the spread spectrum.

The parameters N, P, M1, and M0 are for the frequency division.

When M1 = 0, M0 = 0, and P = 1 (no frequency division), the calculation formula of PLL frequency can be simplified as follows:

$$f = (N+X) \cdot 24MHz, 0 < X < 1$$

$$[f_1, f_2] = (N+1+[X_1, X_2]) \cdot 24MHz$$

$$SDM\_BOT = 2^{17} \cdot X_1$$

$$WAVE\_STEP = 2^{17} \cdot (X_2 - X_1) / (24MHz / PREQ) \cdot 2$$

Where, SDM\_BOT and WAVE\_STEP are bits of the PLL pattern control register, and PREQ is the frequency of the spread spectrum.



#### NOTE

Different PLLs have different calculate formulas, refer to the CTRL register of the corresponding PLL in section 2.5.6 Register Description.

Follow the steps below to implement the spread spectrum:

**Step 1** Configure the control register of the corresponding PLL

- a) Calculate the factor N and decimal value X according to the PLL frequency and PLL frequency formula. Refer to the control register of the corresponding PLL (named PLL\_xxx\_CTRL\_REG, where xxx is the module name) in 2.5.6 Register Description for the corresponding PLL frequency formula.
- b) Write M0, M1, N, and PLL frequency to the PLL control register.
- c) Configure the PLL\_SDM\_EN bit (bit [24]) of the PLL control register to 1 to enable the spread spectrum function.

**Step 2** Configure the pattern control register of the corresponding PLL

- a) Calculate the SDM\_BOT and WAVE\_STEP of the pattern control register according to decimal value X and spread spectrum frequency (the bit [18:17] of the PLL pattern register)
- b) Configure the spread spectrum mode (SPR\_FREQ\_MODE) to 2 or 3.
- c) If the PLL\_INPUT\_DIV2 of the PLL control register is 1, configure the spread spectrum clock source select bit (SDM\_CLK\_SEL) of the PLL pattern control register to 1. Otherwise, configure SDM\_CLK\_SEL to the default value 0.
- d) Write SDM\_BOT, WAVE\_STEP, PREQ, SPR\_FREQ\_MODE, and SDM\_CLK\_SEL to the PLL pattern control register, and configure the SIG\_DELT\_PAT\_EN bit (bit [31]) of this register to 1.

**Step 3** Delay 20 us

#### 2.5.4.6 Configuring Bus Clock

The bus clock supports dynamic switching, but the process of switching needs to follow the following two rules.

- From a higher frequency to a lower frequency: switch the clock source first, and then set the frequency division factor;
- From a lower frequency to a higher frequency: configure the frequency division factor first, and then switch the clock source.

The bus frequency for each bus is as follows:

- AXI: It is suggested to be configured as the CPU clock frequency divided by 3. when the CPU clock frequency is less than 1.2 GHz, AXI frequency could be configured as the CPU clock frequency divided by 2.
- AHB: Maximum 200 MHz
- APB0: Maximum 100 MHz
- APB1: Maximum 160 MHz

- MBUS: Maximum 700 MHz
- IOMMU: Maximum 600 MHz

#### 2.5.4.7 Configuring Module Clock

For the Bus Gating Reset register of a module, the reset bit is de-asserted first, and then the clock gating bit is enabled to avoid potential problems caused by the asynchronous release of the reset signal.

For all module clocks except the DDR clock, configure the clock source and frequency division factor first, and then release the clock gating (that is, set to 1). For the configuration order of the clock source and frequency division factor, follow the rules below:

- With the increasing of the clock source frequency, configure the frequency division factor before the clock source;
- With the decreasing of the clock source frequency, configure the clock source before the frequency division factor.

#### 2.5.5 Register List



##### NOTE

- Before switching the glitch-free MUX, ensure that
  - Every clock source is in use.
  - The switching time is longer than two clock periods of the slowest clock source.
- Before switching the normal MUX, ensure that the clock sources are closed.

| Module Name | Base Address |
|-------------|--------------|
| CCU         | 0x0200 1000  |

| Register Name       | Offset | Description                 |
|---------------------|--------|-----------------------------|
| PLL_DDR_CTRL_REG    | 0x0010 | PLL_DDR Control Register    |
| PLL_PERI0_CTRL_REG  | 0x0020 | PLL_PERI0 Control Register  |
| PLL_PERI1_CTRL_REG  | 0x0028 | PLL_PERI1 Control Register  |
| PLL_GPU_CTRL_REG    | 0x0030 | PLL_GPU Control Register    |
| PLL_VIDEO0_CTRL_REG | 0x0040 | PLL_VIDEO0 Control Register |
| PLL_VIDEO1_CTRL_REG | 0x0048 | PLL_VIDEO1 Control Register |
| PLL_VIDEO2_CTRL_REG | 0x0050 | PLL_VIDEO2 Control Register |
| PLL_VE_CTRL_REG     | 0x0058 | PLL_VE Control Register     |
| PLL_VIDEO3_CTRL_REG | 0x0068 | PLL_VIDEO3 Control Register |
| PLL_AUDIO0_CTRL_REG | 0x0078 | PLL_AUDIO0 Control Register |

| Register Name            | Offset | Description                          |
|--------------------------|--------|--------------------------------------|
| PLL_DDR_PAT0_CTRL_REG    | 0x0110 | PLL_DDR Pattern0 Control Register    |
| PLL_DDR_PAT1_CTRL_REG    | 0x0114 | PLL_DDR Pattern1 Control Register    |
| PLL_PERI0_PAT0_CTRL_REG  | 0x0120 | PLL_PERI0 Pattern0 Control Register  |
| PLL_PERI0_PAT1_CTRL_REG  | 0x0124 | PLL_PERI0 Pattern1 Control Register  |
| PLL_PERI1_PAT0_CTRL_REG  | 0x0128 | PLL_PERI1 Pattern0 Control Register  |
| PLL_PERI1_PAT1_CTRL_REG  | 0x012C | PLL_PERI1 Pattern1 Control Register  |
| PLL_GPU_PAT0_CTRL_REG    | 0x0130 | PLL_GPU Pattern0 Control Register    |
| PLL_GPU_PAT1_CTRL_REG    | 0x0134 | PLL_GPU Pattern1 Control Register    |
| PLL_VIDEO0_PAT0_CTRL_REG | 0x0140 | PLL_VIDEO0 Pattern0 Control Register |
| PLL_VIDEO0_PAT1_CTRL_REG | 0x0144 | PLL_VIDEO0 Pattern1 Control Register |
| PLL_VIDEO1_PAT0_CTRL_REG | 0x0148 | PLL_VIDEO1 Pattern0 Control Register |
| PLL_VIDEO1_PAT1_CTRL_REG | 0x014C | PLL_VIDEO1 Pattern1 Control Register |
| PLL_VIDEO2_PAT0_CTRL_REG | 0x0150 | PLL_VIDEO2 Pattern0 Control Register |
| PLL_VIDEO2_PAT1_CTRL_REG | 0x0154 | PLL_VIDEO2 Pattern1 Control Register |
| PLL_VE_PAT0_CTRL_REG     | 0x0158 | PLL_VE Pattern0 Control Register     |
| PLL_VE_PAT1_CTRL_REG     | 0x015C | PLL_VE Pattern1 Control Register     |
| PLL_VIDEO3_PAT0_CTRL_REG | 0x0168 | PLL_VIDEO3 Pattern0 Control Register |
| PLL_VIDEO3_PAT1_CTRL_REG | 0x016C | PLL_VIDEO3 Pattern1 Control Register |
| PLL_AUDIO0_PAT0_CTRL_REG | 0x0178 | PLL_AUDIO0 Pattern0 Control Register |
| PLL_AUDIO0_PAT1_CTRL_REG | 0x017C | PLL_AUDIO0 Pattern1 Control Register |
| PLL_DDR_BIAS_REG         | 0x0310 | PLL_DDR Bias Register                |
| PLL_PERI0_BIAS_REG       | 0x0320 | PLL_PERI0 Bias Register              |
| PLL_PERI1_BIAS_REG       | 0x0328 | PLL_PERI1 Bias Register              |
| PLL_GPU_BIAS_REG         | 0x0330 | PLL_GPU Bias Register                |
| PLL_VIDEO0_BIAS_REG      | 0x0340 | PLL_VIDEO0 Bias Register             |
| PLL_VIDEO1_BIAS_REG      | 0x0348 | PLL_VIDEO1 Bias Register             |
| PLL_VIDEO2_BIAS_REG      | 0x0350 | PLL_VIDEO2 Bias Register             |
| PLL_VE_BIAS_REG          | 0x0358 | PLL_VE Bias Register                 |
| PLL_VIDEO3_BIAS_REG      | 0x0368 | PLL_VIDEO3 Bias Register             |
| PLL_AUDIO0_BIAS_REG      | 0x0378 | PLL_AUDIO0 Bias Register             |
| AHB_CLK_REG              | 0x0510 | AHB Clock Register                   |
| APB0_CLK_REG             | 0x0520 | APB0 Clock Register                  |
| APB1_CLK_REG             | 0x0524 | APB1 Clock Register                  |
| MBUS_CLK_REG             | 0x0540 | MBUS Clock Register                  |
| NSI_BGR_REG              | 0x054C | NSI Bus Gating Reset Register        |
| GIC_CLK_REG              | 0x0550 | GIC Clock Register                   |
| DE_CLK_REG               | 0x0600 | DE Clock Register                    |
| DE_BGR_REG               | 0x060C | DE Bus Gating Reset Register         |
| DI_CLK_REG               | 0x0620 | DI Clock Register                    |
| DI_BGR_REG               | 0x062C | DI Bus Gating Reset Register         |
| G2D_CLK_REG              | 0x0630 | G2D Clock Register                   |
| G2D_BGR_REG              | 0x063C | G2D Bus Gating Reset Register        |

| Register Name           | Offset | Description                             |
|-------------------------|--------|-----------------------------------------|
| DE_SYS_BGR_REG          | 0x064C | DE_SYS Bus Gating Reset Register        |
| GPU_CLK_REG             | 0x0670 | GPU Clock Register                      |
| GPU_GATING_REG          | 0x067C | GPU Gating Reset Configuration Register |
| CE_CLK_REG              | 0x0680 | CE Clock Register                       |
| CE_BGR_REG              | 0x068C | CE Bus Gating Reset Register            |
| VE_CLK_REG              | 0x0690 | VE Clock Register                       |
| VE_BGR_REG              | 0x069C | VE Bus Gating Reset Register            |
| DMAC_BGR_REG            | 0x070C | DMAC Bus Gating Reset Register          |
| CPUX_MSGBOX_BGR_REG     | 0x071C | CPUX_MSGBOX Bus Gating Reset Register   |
| SPINLOCK_BGR_REG        | 0x072C | SPINLOCK Bus Gating Reset Register      |
| CPUX_TIMER0_CLK_REG     | 0x0730 | CPUX_TIMER0 Clock Register              |
| CPUX_TIMER1_CLK_REG     | 0x0734 | CPUX_TIMER1 Clock Register              |
| CPUX_TIMER2_CLK_REG     | 0x0738 | CPUX_TIMER2 Clock Register              |
| CPUX_TIMER3_CLK_REG     | 0x073C | CPUX_TIMER3 Clock Register              |
| CPUX_TIMER4_CLK_REG     | 0x0740 | CPUX_TIMER4 Clock Register              |
| CPUX_TIMER5_CLK_REG     | 0x0744 | CPUX_TIMER5 Clock Register              |
| CPUX_TIMER_BGR_REG      | 0x074C | CPUX_TIMER Bus Gating Reset Register    |
| DBGSYS_BGR_REG          | 0x078C | DBGSYS Bus Gating Reset Register        |
| PWMCTRL_BGR_REG         | 0x07AC | PWMCTRL Bus Gating Reset Register       |
| IOMMU_CLK_REG           | 0x07B0 | IOMMU Clock Register                    |
| IOMMU_BGR_REG           | 0x07BC | IOMMU Bus Gating Reset Register         |
| DRAM_CLK_REG            | 0x0800 | DRAM Clock Register                     |
| MBUS_MAT_CLK_GATING_REG | 0x0804 | MBUS Master Clock Gating Register       |
| DRAM_BGR_REG            | 0x080C | DRAM Bus Gating Reset Register          |
| NDFC_CLK0_CLK_REG       | 0x0810 | NDFC CLK0 Clock Register                |
| NDFC_CLK1_CLK_REG       | 0x0814 | NDFC CLK1 Clock Register                |
| NDFC_BGR_REG            | 0x082C | NDFC Bus Gating Reset Register          |
| SMHC0_CLK_REG           | 0x0830 | SMHC0 Clock Register                    |
| SMHC1_CLK_REG           | 0x0834 | SMHC1 Clock Register                    |
| SMHC2_CLK_REG           | 0x0838 | SMHC2 Clock Register                    |
| SMHC_BGR_REG            | 0x084C | SMHC Bus Gating Reset Register          |
| SYSDAP_BGR_REG          | 0x088C | SYSDAP Bus Gating Reset Register        |
| UART_BGR_REG            | 0x090C | UART Bus Gating Reset Register          |
| TWI_BGR_REG             | 0x091C | TWI Bus Gating Reset Register           |
| SPI0_CLK_REG            | 0x0940 | SPI0 Clock Register                     |
| SPI1_CLK_REG            | 0x0944 | SPI1 Clock Register                     |
| SPI2_CLK_REG            | 0x0948 | SPI2 Clock Register                     |
| SPIFC_CLK_REG           | 0x0950 | SPIFC Clock Register                    |
| SPI_BGR_REG             | 0x096C | SPI Bus Gating Reset Register           |
| GMAC_25M_CLK_REG        | 0x0970 | GMAC_25M Clock Register                 |
| GMAC_BGR_REG            | 0x097C | GMAC Bus Gating Reset Register          |
| IRRX_CLK_REG            | 0x0990 | IRRX Clock Register                     |

| Register Name         | Offset | Description                            |
|-----------------------|--------|----------------------------------------|
| IRRX_BGR_REG          | 0x099C | IRRX Bus Gating Reset Register         |
| IRTX_CLK_REG          | 0x09C0 | IRTX Clock Register                    |
| IRTX_BGR_REG          | 0x09CC | IRTX Bus Gating Reset Register         |
| GPADC_24M_CLK_REG     | 0x09E0 | GPADC_24M Clock Register               |
| GPADC_BGR_REG         | 0x09EC | GPADC Bus Gating Reset Register        |
| THS_BGR_REG           | 0x09FC | THS Bus Gating Reset Register          |
| USB0_CLK_REG          | 0x0A70 | USB0 Clock Register                    |
| USB1_CLK_REG          | 0x0A74 | USB1 Clock Register                    |
| USB2_REF_CLK_REG      | 0x0A80 | USB2_REF Clock Register                |
| USB3_PCIE_REF_CLK_REG | 0x0A84 | USB3_PCIE Reference Clock Register     |
| USB3_SUSPEND_CLK_REG  | 0x0A88 | USB3_SUSPEND Clock Register            |
| USB_BGR_REG           | 0x0A8C | USB Bus Gating Reset Register          |
| LRADC_BGR_REG         | 0x0A9C | LRADC Bus Gating Reset Register        |
| PCIE_AUX_CLK_REG      | 0x0AA0 | PCIE_AUX Clock Register                |
| PCIE_BGR_REG          | 0x0AAC | PCIE Bus Gating Reset Register         |
| DISPLAY0_TOP_BGR_REG  | 0x0ABC | DISPLAY0_TOP Bus Gating Reset Register |
| DSI0_CLK_REG          | 0x0B24 | DSI0 Clock Register                    |
| DSI1_CLK_REG          | 0x0B28 | DSI1 Clock Register                    |
| DSI_BGR_REG           | 0x0B4C | DSI Bus Gating Reset Register          |
| TCONLCD0_CLK_REG      | 0x0B60 | TCONLCD0 Clock Register                |
| TCONLCD1_CLK_REG      | 0x0B64 | TCONLCD1 Clock Register                |
| COMBOPHY_DSI0_CLK_REG | 0x0B6C | COMBOPHY_DSI0 Clock Register           |
| COMBOPHY_DSI1_CLK_REG | 0x0B70 | COMBOPHY_DSI1 Clock Register           |
| TCONLCD_BGR_REG       | 0x0B7C | TCONLCD Bus Gating Reset Register      |
| TCONTV1_CLK_REG       | 0x0B84 | TCONTV1 Clock Register                 |
| TCONTV_BGR_REG        | 0x0B9C | TCONTV Bus Gating Reset Register       |
| LVDS_BGR_REG          | 0x0BAC | LVDS Bus Gating Reset Register         |
| EDP_CLK_REG           | 0x0BB0 | EDP Clock Register                     |
| EDP_BGR_REG           | 0x0BBC | EDP Bus Gating Reset Register          |
| VIDEO_OUT_BGR_REG     | 0x0BCC | Video out Bus Gating Reset Register    |
| LEDC_CLK_REG          | 0x0BF0 | LEDC Clock Register                    |
| LEDC_BGR_REG          | 0x0BFC | LEDC Bus Gating Reset Register         |
| CSI_CLK_REG           | 0x0C04 | CSI Clock Register                     |
| CSI_MASTER0_CLK_REG   | 0x0C08 | CSI Master0 Clock Register             |
| CSI_MASTER1_CLK_REG   | 0x0C0C | CSI Master1 Clock Register             |
| CSI_MASTER2_CLK_REG   | 0x0C10 | CSI Master2 Clock Register             |
| CSI_MASTER3_CLK_REG   | 0x0C14 | CSI Master3 Clock Register             |
| CSI_BGR_REG           | 0x0C1C | CSI Bus Gating Reset Register          |
| ISP_CLK_REG           | 0x0C20 | ISP Clock Register                     |
| AHB_GATE_EN_REG       | 0x0E04 | AHB Gate Enable Register               |
| PERI0PLL_GATE_EN_REG  | 0x0E08 | PERI0PLL Gate Enable Register          |
| CLK24M_GATE_EN_REG    | 0x0E0C | CLK24M Gate Enable Register            |

| Register Name        | Offset | Description                           |
|----------------------|--------|---------------------------------------|
| PERI1PLL_GATE_EN_REG | 0x0E10 | PERI1PLL Gate Enable Register         |
| VIDEOPLL_GATE_EN_REG | 0x0E14 | VIDEOPLL Gate Enable Register         |
| CM_GPU_CFG_REG       | 0x0E20 | CM GPU Enable Configuration Register  |
| CM_VE_CFG_REG        | 0x0E24 | CM VE Enable Configuration Register   |
| CM_DE_CFG_REG        | 0x0E28 | CM DE Enable Configuration Register   |
| CM_VI_CFG_REG        | 0x0E2C | CM VI Enable Configuration Register   |
| CM_VOO_CFG_REG       | 0x0E30 | CM VOO Enable Configuration Register  |
| CM_NDFC_CFG_REG      | 0x0E38 | CM NDFC Enable Configuration Register |
| CM_PCIE_CFG_REG      | 0x0E3C | CM PCIe Enable Configuration Register |
| CCMU_SEC_SWITCH_REG  | 0x0F00 | CCMU Security Switch Register         |
| SYSDAP_REQ_CTRL_REG  | 0x0F08 | SYSDAP REQ Control Register           |
| CCMU_FAN_GATE_REG    | 0x0F30 | CCMU FANOUT CLOCK GATE Register       |
| CLK27M_FAN_REG       | 0x0F34 | CLK27M FANOUT Register                |
| CLK_FAN_REG          | 0x0F38 | CLK FANOUT Register                   |
| CCMU_FAN_REG         | 0x0F3C | CCMU FANOUT Register                  |
| PLL_CFG0_REG         | 0x0F40 | PLL Configuration0 Register           |
| PLL_CFG1_REG         | 0x0F44 | PLL Configuration1 Register           |
| PLL_CFG2_REG         | 0x0F48 | PLL Configuration2 Register           |

## 2.5.6 Register Description

### 2.5.6.1 0x0010 PLL\_DDR Control Register (Default Value: 0x4800\_2301)

| Offset: 0x0010 |            |             | Register Name: PLL_DDR_CTRL_REG                                                                                                                                    |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                        |
| 31             | R/W        | 0x0         | PLL_EN<br>PLL Enable<br>0: Disable<br>1: Enable<br>The DDRPLL= InputFreq*N/M1/M0<br>The default value of PLL_DDR is 432 MHz when the crystal oscillator is 24 MHz. |
| 30             | R/W        | 0x1         | PLL_LDO_EN<br>LDO Enable<br>0: Disable<br>1: Enable                                                                                                                |
| 29             | R/W        | 0x0         | LOCK_ENABLE<br>Lock Enable<br>0: Disable<br>1: Enable                                                                                                              |
| 28             | R          | 0x0         | LOCK                                                                                                                                                               |

| Offset: 0x0010 |            |             | Register Name: PLL_DDR_CTRL_REG                                                                                                    |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                        |
|                |            |             | PLL Lock Info<br>0: Unlocked<br>1: Locked (It indicates that the PLL has been stable.)                                             |
| 27             | R/W        | 0x1         | PLL_OUTPUT_GATE<br>PLL Output Gating Enable<br>0: Disable<br>1: Enable<br>The bit is used to control the output enable of the PLL. |
| 26:25          | /          | /           | /                                                                                                                                  |
| 24             | R/W        | 0x0         | PLL_SDM_EN<br>PLL SDM Enable<br>0: Disable<br>1:Enable                                                                             |
| 23:16          | /          | /           | /                                                                                                                                  |
| 15:8           | R/W        | 0x23        | PLL_N<br>PLL N<br>N= PLL_N +1<br>PLL_N is from 0 to 254.<br>In application, PLL_N shall be more than or equal to 11.               |
| 7:6            | R/W        | 0x0         | PLL_UNLOCK_MDSEL<br>PLL Unlock Level<br>00: 21-29 Clock Cycles<br>01: 22-28 Clock Cycles<br>1X: 20-30 Clock Cycles                 |
| 5              | R/W        | 0x0         | PLL_LOCK_MDSEL<br>PLL Lock Level<br>0: 24-26 Clock Cycles<br>1: 23-27 Clock Cycles                                                 |
| 4:2            | /          | /           | /                                                                                                                                  |
| 1              | R/W        | 0x0         | PLL_INPUT_DIV2<br>PLL Input Div M1<br>M1=PLL_INPUT_DIV2 + 1<br>PLL_INPUT_DIV2 is from 0 to 1.                                      |
| 0              | R/W        | 0x1         | PLL_OUTPUT_DIV2<br>PLL Output Div M0<br>M0=PLL_OUTPUT_DIV2 + 1<br>PLL_OUTPUT_DIV2 is from 0 to 1.                                  |

#### 2.5.6.2 0x0020 PLL\_PERIO Control Register (Default Value: 0x4821\_6310)

| Offset: 0x0020 | Register Name: PLL_PERIO_CTRL_REG |
|----------------|-----------------------------------|
|----------------|-----------------------------------|

| Bit   | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | R/W        | 0x0         | <p>PLL_EN<br/>PLL Enable<br/>0: Disable<br/>1: Enable</p> <p>PERI0PLL2X = 24MHz*N/M1/P0<br/>PERI0_800M = 24MHz*N/M1/P1<br/>PERI0_480M = 24MHz*N/M1/P2<br/>PERI0_600M = PERI0PLL2X/2<br/>PERI0_400M = PERI0PLL2X/3<br/>PERI0_300M = PERI0_600M/2<br/>PERI0_200M = PERI0_400M/2<br/>PERI0_160M = PERI0_480M/3<br/>PERI0_150M = PERI0_300M/2</p> <p>When the crystal oscillator is 24 MHz, the default frequency of PERI0PLL2X is 1.2 GHz, the default frequency of PERI0_800M is 800 MHz, and the default frequency of PERI0_480M is 480 MHz.</p> <p>The output clock of PERI0PLL2X is fixed to 1.2 GHz and not suggested to change the parameter.</p> |
| 30    | R/W        | 0x1         | <p>PLL_LDO_EN<br/>LDO Enable<br/>0: Disable<br/>1: Enable</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 29    | R/W        | 0x0         | <p>LOCK_ENABLE<br/>Lock Enable<br/>0: Disable<br/>1: Enable</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 28    | R          | 0x0         | <p>LOCK<br/>PLL Lock Info<br/>0: Unlocked<br/>1: Locked (It indicates that the PLL has been stable.)</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 27    | R/W        | 0x1         | <p>PLL_OUTPUT_GATE<br/>PLL Output Gating Enable<br/>0: Disable<br/>1: Enable</p> <p>The bit is used to control the output enable of the PLL.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 26:25 | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 24    | R/W        | 0x0         | <p>PLL_SDM_EN<br/>PLL SDM Enable<br/>0: Disable<br/>1: Enable</p> <p>Enable spread spectrum and decimal division.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 23    | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

| Offset: 0x0020 |            |             | Register Name: PLL_PERI0_CTRL_REG                                                                                       |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                             |
| 22:20          | R/W        | 0x2         | PLL_P1<br>PLL Output Div P1<br>$P1=PLL\_P1 + 1$<br>PLL_P1 is from 0 to 7.                                               |
| 19             | /          | /           | /                                                                                                                       |
| 18:16          | R/W        | 0x1         | PLL_P0<br>PLL Output Div P0<br>$P0=PLL\_P0 + 1$<br>PLL_P0 is from 0 to 7.                                               |
| 15:8           | R/W        | 0x63        | PLL_N<br>PLL N<br>$N=PLL\_N + 1$<br>PLL_N is from 0 to 254.<br>In application, PLL_N shall be more than or equal to 11. |
| 7:6            | R/W        | 0x0         | PLL_UNLOCK_MDSEL<br>PLL Unlock Level<br>00: 21-29 Clock Cycles<br>01: 22-28 Clock Cycles<br>1X: 20-30 Clock Cycles      |
| 5              | R/W        | 0x0         | PLL_LOCK_MDSEL<br>PLL Lock Level<br>0: 24-26 Clock Cycles<br>1: 23-27 Clock Cycles                                      |
| 4:2            | R/W        | 0x4         | PLL_P2<br>PLL Output Div P2<br>$P2=PLL\_P2 + 1$<br>PLL_P2 is from 0 to 7.                                               |
| 1              | R/W        | 0x0         | PLL_INPUT_DIV2<br>PLL Input Div M1<br>$M1=PLL\_INPUT\_DIV2 + 1$<br>PLL_INPUT_DIV2 is from 0 to 1.                       |
| 0              | /          | /           | /                                                                                                                       |

### 2.5.6.3 0x0028 PLL\_PERI1 Control Register (Default Value: 0x4821\_6310)

| Offset: 0x0028 |            |             | Register Name: PLL_PERI1_CTRL_REG               |
|----------------|------------|-------------|-------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                     |
| 31             | R/W        | 0x0         | PLL_EN<br>PLL Enable<br>0: Disable<br>1: Enable |

| Offset: 0x0028 |            |             | Register Name: PLL_PERI1_CTRL_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                |            |             | <p>PERI1PLL2X = 24MHz*N/M1/P0<br/>         PERI1_800M = 24MHz*N/M1/P1<br/>         PERI1_480M = 24MHz*N/M1/P2<br/>         PERI1_600M = PERI1PLL2X/2<br/>         PERI1_400M = PERI1PLL2X/3<br/>         PERI1_300M = PERI1_600M/2<br/>         PERI1_200M = PERI1_400M/2<br/>         PERI1_160M = PERI1_480M/3<br/>         PERI1_150M = PERI1_300M/2</p> <p>When the crystal oscillator is 24 MHz, the default frequency of PERI1PLL2X is 1.2 GHz, the default frequency of PERI1_800M is 800 MHz, and the default frequency of PERI1_480M is 480 MHz.</p> <p>The output clock of PERI1PLL2X is fixed to 1.2 GHz and not suggested to change the parameter.</p> |
| 30             | R/W        | 0x1         | <p>PLL_LDO_EN<br/>         LDO Enable<br/>         0: Disable<br/>         1: Enable</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 29             | R/W        | 0x0         | <p>LOCK_ENABLE<br/>         Lock Enable<br/>         0: Disable<br/>         1: Enable</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 28             | R          | 0x0         | <p>LOCK<br/>         PLL Lock Info<br/>         0: Unlocked<br/>         1: Locked (It indicates that the PLL has been stable.)</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 27             | R/W        | 0x1         | <p>PLL_OUTPUT_GATE<br/>         PLL Output Gating Enable<br/>         0: Disable<br/>         1: Enable</p> <p>The bit is used to control the output enable of the PLL.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 26:25          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 24             | R/W        | 0x0         | <p>PLL_SDM_EN<br/>         PLL SDM Enable<br/>         0: Disable<br/>         1: Enable</p> <p>Enable spread spectrum and decimal division.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 23             | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 22:20          | R/W        | 0x2         | <p>PLL_P1<br/>         PLL Output Div P1</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

| Offset: 0x0028 |            |             | Register Name: PLL_PERI1_CTRL_REG                                                                                     |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                           |
|                |            |             | P1=PLL_P1 + 1<br>PLL_P1 is from 0 to 7.                                                                               |
| 19             | /          | /           | /                                                                                                                     |
| 18:16          | R/W        | 0x1         | PLL_P0<br>PLL Output Div P0<br>P0=PLL_P0 + 1<br>PLL_P0 is from 0 to 7.                                                |
| 15:8           | R/W        | 0x63        | PLL_N<br>PLL N.<br>N= PLL_N +1<br>PLL_N is from 0 to 254.<br>In application, PLL_N shall be more than or equal to 11. |
| 7:6            | R/W        | 0x0         | PLL_UNLOCK_MDSEL<br>PLL Unlock Level<br>00: 21-29 Clock Cycles<br>01: 22-28 Clock Cycles<br>1X: 20-30 Clock Cycles    |
| 5              | R/W        | 0x0         | PLL_LOCK_MDSEL<br>PLL Lock Level<br>0: 24-26 Clock Cycles<br>1: 23-27 Clock Cycles                                    |
| 4:2            | R/W        | 0x4         | PLL_P2<br>PLL Output Div P2<br>P2=PLL_P2 + 1<br>PLL_P2 is from 0 to 7.                                                |
| 1              | R/W        | 0x0         | PLL_INPUT_DIV2<br>PLL Input Div M1<br>M1=PLL_INPUT_DIV2 + 1<br>PLL_INPUT_DIV2 is from 0 to 1.                         |
| 0              | /          | /           | /                                                                                                                     |

#### 2.5.6.4 0x0030 PLL\_GPU Control Register (Default Value: 0x4800\_2301)

| Offset: 0x0030 |            |             | Register Name: PLL_GPU_CTRL_REG                                                                                                                                                   |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                       |
| 31             | R/W        | 0x0         | PLL_EN<br>PLL Enable<br>0: Disable<br>1: Enable<br>The $\text{PLL\_GPU} = \text{InputFreq} * \text{N} / \text{M1/M0}$<br>The default value of PLL_GPU is 432 MHz when the crystal |

| Offset: 0x0030 |            |             | Register Name: PLL_GPU_CTRL_REG                                                                                             |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                 |
|                |            |             | oscillator is 24 MHz.                                                                                                       |
| 30             | R/W        | 0x1         | PLL_LDO_EN<br>LDO Enable<br>0: Disable<br>1: Enable                                                                         |
| 29             | R/W        | 0x0         | LOCK_ENABLE<br>Lock Enable<br>0: Disable<br>1: Enable                                                                       |
| 28             | R          | 0x0         | LOCK<br>PLL Lock Info<br>0: Unlocked<br>1: Locked (It indicates that the PLL has been stable.)                              |
| 27             | R/W        | 0x1         | PLL_OUTPUT_GATE<br>PLL Output Enable<br>0: Disable<br>1: Enable<br>The bit is used to control the output enable of the PLL. |
| 26:25          | /          | /           | /                                                                                                                           |
| 24             | R/W        | 0x0         | PLL_SDM_EN<br>PLL SDM Enable<br>0: Disable.<br>1: Enable                                                                    |
| 23:16          | /          | /           | /                                                                                                                           |
| 15:8           | R/W        | 0x23        | PLL_N<br>PLL Factor N<br>N= PLL_N +1<br>PLL_N is from 0 to 254.<br>In application, PLL_N shall be more than or equal to 11. |
| 7:6            | R/W        | 0x0         | PLL_UNLOCK_MDSEL<br>PLL Unlock Level<br>00: 21-29 Clock Cycles<br>01: 22-28 Clock Cycles<br>1X: 20-30 Clock Cycles          |
| 5              | R/W        | 0x0         | PLL_LOCK_MDSEL<br>PLL Lock Level<br>0: 24-26 Clock Cycles<br>1: 23-27 Clock Cycles                                          |
| 4:2            | /          | /           | /                                                                                                                           |
| 1              | R/W        | 0x0         | PLL_INPUT_DIV2<br>PLL Input Div M1                                                                                          |

| Offset: 0x0030 |            |             | Register Name: PLL_GPU_CTRL_REG                                                                  |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                      |
|                |            |             | M1=PLL_INPUT_DIV2 + 1<br>PLL_INPUT_DIV2 is from 0 to 1                                           |
| 0              | R/W        | 0x1         | PLL_OUTPUT_DIV2<br>PLL Output Div M0<br>M0=PLL_OUTPUT_DIV2 + 1<br>PLL_OUTPUT_DIV2 is from 0 to 1 |

#### 2.5.6.5 0x0040 PLL\_VIDEO0 Control Register (Default Value: 0x4800\_6201)

| Offset: 0x0040 |            |             | Register Name: PLL_VIDEO0_CTRL_REG                                                                                                                                                                                                        |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                               |
| 31             | R/W        | 0x0         | PLL_EN<br>PLL Enable<br>0: Disable<br>1: Enable<br>For application,<br>VIDEO0PLL4X = InputFreq *N/M1/M0<br>VIDEO0PLL3X = InputFreq *N/M1/3<br>The default value of VIDEO0PLL4X is 1188MHz=24*99/2, when the crystal oscillator is 24 MHz. |
| 30             | R/W        | 0x1         | PLL_LDO_EN<br>LDO Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                       |
| 29             | R/W        | 0x0         | LOCK_ENABLE<br>Lock Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                     |
| 28             | R          | 0x0         | LOCK<br>PLL Lock Info<br>0: Unlocked<br>1: Locked (It indicates that the PLL has been stable.)                                                                                                                                            |
| 27             | R/W        | 0x1         | PLL_OUTPUT_GATE<br>PLL Output Gating Enable<br>0: Disable<br>1: Enable<br>The bit is used to control the output enable of the PLL.                                                                                                        |
| 26:25          | /          | /           | /                                                                                                                                                                                                                                         |
| 24             | R/W        | 0x0         | PLL_SDM_EN.<br>PLL SDM Enable<br>0: Disable                                                                                                                                                                                               |

| Offset: 0x0040 |            |             | Register Name: PLL_VIDEO0_CTRL_REG                                                                                   |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                          |
|                |            |             | 1: Enable                                                                                                            |
| 23:16          | /          | /           | /                                                                                                                    |
| 15:8           | R/W        | 0x62        | PLL_N<br>PLL N<br>N= PLL_N +1<br>PLL_N is from 0 to 254.<br>In application, PLL_N shall be more than or equal to 11. |
| 7:6            | R/W        | 0x0         | PLL_UNLOCK_MDSEL<br>PLL Unlock Level<br>00: 21-29 Clock Cycles<br>01: 22-28 Clock Cycles<br>1X: 20-30 Clock Cycles   |
| 5              | R/W        | 0x0         | PLL_LOCK_MDSEL<br>PLL Lock Level<br>0: 24-26 Clock Cycles<br>1: 23-27 Clock Cycles                                   |
| 4:2            | /          | /           | /                                                                                                                    |
| 1              | R/W        | 0x0         | PLL_INPUT_DIV2<br>PLL Input Div M1<br>M1=PLL_INPUT_DIV2 + 1<br>PLL_INPUT_DIV2 is from 0 to 1.                        |
| 0              | R/W        | 0x1         | PLL_OUTPUT_DIV2<br>PLL Output Div M0<br>M0=PLL_OUTPUT_DIV2 + 1<br>PLL_OUTPUT_DIV2 is from 0 to 1.                    |

#### 2.5.6.6 0x0048 PLL\_VIDEO1 Control Register (Default Value: 0x4800\_6201)

| Offset: 0x0048 |            |             | Register Name: PLL_VIDEO1_CTRL_REG                                                                                                                                                                                                                                                            |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                   |
| 31             | R/W        | 0x0         | PLL_EN.<br>PLL Enable<br>0: Disable<br>1: Enable<br>For application,<br>$\text{VIDEO1PLL4X} = \text{InputFreq} * \text{N/M1/M0}$<br>$\text{VIDEO1PLL3X} = \text{InputFreq} * \text{N/M1/3}$<br>The default value of VIDEO1PLL4X is 1188MHz=24*99/2,<br>when the crystal oscillator is 24 MHz. |
| 30             | R/W        | 0x1         | PLL_LDO_EN                                                                                                                                                                                                                                                                                    |
|                |            |             | LDO Enable                                                                                                                                                                                                                                                                                    |

| Offset: 0x0048 |            |             | Register Name: PLL_VIDEO1_CTRL_REG                                                                                                 |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                        |
|                |            |             | 0: Disable<br>1: Enable                                                                                                            |
| 29             | R/W        | 0x0         | LOCK_ENABLE<br>Lock Enable<br>0: Disable<br>1: Enable                                                                              |
| 28             | R          | 0x0         | LOCK<br>PLL Lock Info<br>0: Unlocked<br>1: Locked (It indicates that the PLL has been stable.)                                     |
| 27             | R/W        | 0x1         | PLL_OUTPUT_GATE<br>PLL Output Gating Enable<br>0: Disable<br>1: Enable<br>The bit is used to control the output enable of the PLL. |
| 26:25          | /          | /           | /                                                                                                                                  |
| 24             | R/W        | 0x0         | PLL_SDM_EN<br>PLL SDM Enable<br>0: Disable<br>1: Enable                                                                            |
| 23:16          | /          | /           | /                                                                                                                                  |
| 15:8           | R/W        | 0x62        | PLL_N<br>PLL N<br>N=PLL_N +1<br>PLL_N is from 0 to 254.<br>In application, PLL_N shall be more than or equal to 11.                |
| 7:6            | R/W        | 0x0         | PLL_UNLOCK_MDSEL<br>PLL Unlock Level<br>00: 21-29 Clock Cycles<br>01: 22-28 Clock Cycles<br>1X: 20-30 Clock Cycles                 |
| 5              | R/W        | 0x0         | PLL_LOCK_MDSEL<br>PLL Lock Level<br>0: 24-26 Clock Cycles<br>1: 23-27 Clock Cycles                                                 |
| 4:2            | /          | /           | /                                                                                                                                  |
| 1              | R/W        | 0x0         | PLL_INPUT_DIV2<br>PLL Input Div M1<br>M1=PLL_INPUT_DIV2 + 1<br>PLL_INPUT_DIV2 is from 0 to 1.                                      |
| 0              | R/W        | 0x1         | PLL_OUTPUT_DIV2                                                                                                                    |

| Offset: 0x0048 |            |             | Register Name: PLL_VIDEO1_CTRL_REG                                             |
|----------------|------------|-------------|--------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                    |
|                |            |             | PLL Output Div M0<br>M0=PLL_OUTPUT_DIV2 + 1<br>PLL_OUTPUT_DIV2 is from 0 to 1. |

#### 2.5.6.7 0x0050 PLL\_VIDEO2 Control Register (Default Value: 0x4800\_6201)

| Offset: 0x0050 |            |             | Register Name: PLL_VIDEO2_CTRL_REG                                                                                                                                                                                                            |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                   |
| 31             | R/W        | 0x0         | PLL_EN<br>PLL Enable<br>0: Disable<br>1: Enable<br>For application,<br>VIDEO2PLL4X = InputFreq *N/M1/M0.<br>VIDEO2PLL3X = InputFreq *N/M1/3.<br>The default value of VIDEO2PLL4X is 1188MHz=24*99/2,<br>when the crystal oscillator is 24 MHz |
| 30             | R/W        | 0x1         | PLL_LDO_EN<br>LDO Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                           |
| 29             | R/W        | 0x0         | LOCK_ENABLE<br>Lock Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                         |
| 28             | R          | 0x0         | LOCK<br>PLL Lock Info<br>0: Unlocked<br>1: Locked (It indicates that the PLL has been stable.)                                                                                                                                                |
| 27             | R/W        | 0x1         | PLL_OUTPUT_GATE<br>PLL Output Gating Enable<br>0: Disable<br>1: Enable<br>The bit is used to control the output enable of the PLL.                                                                                                            |
| 26:25          | /          | /           | /                                                                                                                                                                                                                                             |
| 24             | R/W        | 0x0         | PLL_SDM_EN<br>PLL SDM Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                       |
| 23:16          | /          | /           | /                                                                                                                                                                                                                                             |
| 15:8           | R/W        | 0x62        | PLL_N                                                                                                                                                                                                                                         |

| Offset: 0x0050 |            |             | Register Name: PLL_VIDEO2_CTRL_REG                                                                                 |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                        |
|                |            |             | PLL N<br>N= PLL_N +1<br>PLL_N is from 0 to 254.<br>In application, PLL_N shall be more than or equal to 11.        |
| 7:6            | R/W        | 0x0         | PLL_UNLOCK_MDSEL<br>PLL Unlock Level<br>00: 21-29 Clock Cycles<br>01: 22-28 Clock Cycles<br>1X: 20-30 Clock Cycles |
| 5              | R/W        | 0x0         | PLL_LOCK_MDSEL<br>PLL Lock Level<br>0: 24-26 Clock Cycles<br>1: 23-27 Clock Cycles                                 |
| 4:2            | /          | /           | /                                                                                                                  |
| 1              | R/W        | 0x0         | PLL_INPUT_DIV2<br>PLL Input Div M1<br>M1=PLL_INPUT_DIV2 + 1<br>PLL_INPUT_DIV2 is from 0 to 1.                      |
| 0              | R/W        | 0x1         | PLL_OUTPUT_DIV2<br>PLL Output Div M0<br>M0=PLL_OUTPUT_DIV2 + 1<br>PLL_OUTPUT_DIV2 is from 0 to 1.                  |

#### 2.5.6.8 0x0058 PLL\_VE Control Register (Default Value: 0x4800\_2301)

| Offset: 0x0058 |            |             | Register Name: PLL_VE_CTRL_REG                                                                                                                                                     |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                        |
| 31             | R/W        | 0x0         | PLL_EN<br>PLL Enable<br>0: Disable<br>1: Enable<br>The $PLL\_VE = \text{InputFreq} * N / M1 / M0$<br>The default value of PLL_VE is 432 MHz when the crystal oscillator is 24 MHz. |
| 30             | R/W        | 0x1         | PLL_LDO_EN<br>LDO Enable<br>0: Disable<br>1: Enable                                                                                                                                |
| 29             | R/W        | 0x0         | LOCK_ENABLE<br>Lock Enable<br>0: Disable                                                                                                                                           |

| Offset: 0x0058 |            |             | Register Name: PLL_VE_CTRL_REG                                                                                                     |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                        |
|                |            |             | 1: Enable                                                                                                                          |
| 28             | R          | 0x0         | LOCK<br>PLL Lock Info<br>0: Unlocked<br>1: Locked (It indicates that the PLL has been stable.)                                     |
| 27             | R/W        | 0x1         | PLL_OUTPUT_GATE<br>PLL Output Gating Enable<br>0: Disable<br>1: Enable<br>The bit is used to control the output enable of the PLL. |
| 26:25          | /          | /           | /                                                                                                                                  |
| 24             | R/W        | 0x0         | PLL_SDM_EN<br>PLL SDM Enable<br>0: Disable<br>1: Enable                                                                            |
| 23:16          | /          | /           | /                                                                                                                                  |
| 15:8           | R/W        | 0x23        | PLL_N<br>PLL N<br>N= PLL_N +1<br>PLL_N is from 0 to 254.<br>In application, PLL_N shall be more than or equal to 11.               |
| 7:6            | R/W        | 0x0         | PLL_UNLOCK_MDSEL<br>PLL Unlock Level<br>00: 21-29 Clock Cycles<br>01: 22-28 Clock Cycles<br>1X: 20-30 Clock Cycles                 |
| 5              | R/W        | 0x0         | PLL_LOCK_MDSEL<br>PLL Lock Level<br>0: 24-26 Clock Cycles<br>1: 23-27 Clock Cycles                                                 |
| 4:2            | /          | /           | /                                                                                                                                  |
| 1              | R/W        | 0x0         | PLL_INPUT_DIV2<br>PLL Input Div M1<br>M1=PLL_INPUT_DIV2 + 1<br>PLL_INPUT_DIV2 is from 0 to 1.                                      |
| 0              | R/W        | 0x1         | PLL_OUTPUT_DIV2<br>PLL Output Div M0<br>M0=PLL_OUTPUT_DIV2 + 1<br>PLL_OUTPUT_DIV2 is from 0 to 1.                                  |

## 2.5.6.9 0x0068 PLL\_VIDEO3 Control Register (Default Value: 0x4800\_6201)

| Offset: 0x0068 |            |             | Register Name: PLL_VIDEO3_CTRL_REG                                                                                                                                                                                                                                                     |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                            |
| 31             | R/W        | 0x0         | PLL_EN<br>PLL Enable<br>0: Disable<br>1: Enable<br>For application,<br>$\text{VIDEO3PLL4X} = \text{InputFreq} * N / M1 / M0$<br>$\text{VIDEO3PLL3X} = \text{InputFreq} * N / M1 / 3$<br>The default value of VIDEO3PLL4X is 1188MHz=24*99/2,<br>when the crystal oscillator is 24 MHz. |
| 30             | R/W        | 0x1         | PLL_LDO_EN<br>LDO Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                    |
| 29             | R/W        | 0x0         | LOCK_ENABLE<br>Lock Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                  |
| 28             | R          | 0x0         | LOCK<br>PLL Lock Info<br>0: Unlocked<br>1: Locked (It indicates that the PLL has been stable.)                                                                                                                                                                                         |
| 27             | R/W        | 0x1         | PLL_OUTPUT_GATE<br>PLL Output Gating Enable<br>0: Disable<br>1: Enable<br>The bit is used to control the output enable of the PLL.                                                                                                                                                     |
| 26:25          | /          | /           | /                                                                                                                                                                                                                                                                                      |
| 24             | R/W        | 0x0         | PLL_SDM_EN<br>PLL SDM Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                |
| 23:16          | /          | /           | /                                                                                                                                                                                                                                                                                      |
| 15:8           | R/W        | 0x62        | PLL_N<br>PLL N<br>$N = \text{PLL\_N} + 1$<br>PLL_N is from 0 to 254.<br>In application, PLL_N shall be more than or equal to 11.                                                                                                                                                       |
| 7:6            | R/W        | 0x0         | PLL_UNLOCK_MDSEL<br>PLL Unlock Level                                                                                                                                                                                                                                                   |

| Offset: 0x0068 |            |             | Register Name: PLL_VIDEO3_CTRL_REG                                                                |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                       |
|                |            |             | 00: 21-29 Clock Cycles<br>01: 22-28 Clock Cycles<br>1X: 20-30 Clock Cycles                        |
| 5              | R/W        | 0x0         | PLL_LOCK_MDSEL<br>PLL Lock Level<br>0: 24-26 Clock Cycles<br>1: 23-27 Clock Cycles                |
| 4:2            | /          | /           | /                                                                                                 |
| 1              | R/W        | 0x0         | PLL_INPUT_DIV2<br>PLL Input Div M1<br>M1=PLL_INPUT_DIV2 + 1<br>PLL_INPUT_DIV2 is from 0 to 1.     |
| 0              | R/W        | 0x1         | PLL_OUTPUT_DIV2<br>PLL Output Div M0<br>M0=PLL_OUTPUT_DIV2 + 1<br>PLL_OUTPUT_DIV2 is from 0 to 1. |

#### 2.5.6.10 0x0078 PLL\_AUDIO0 Control Register (Default Value: 0x4814\_5500)

| Offset: 0x0078 |            |             | Register Name: PLL_AUDIO0_CTRL_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 31             | R/W        | 0x0         | PLL_EN<br>PLL Enable<br>0: Disable<br>1: Enable<br>$\text{AUDIO0PLL4X} = 24\text{MHz} * \text{N} / \text{M1/M0/P}$<br>$\text{AUDIO0PLL2X} = 24\text{MHz} * \text{N} / \text{M1/M0/P/2}$<br>$\text{AUDIO0PLL1X} = 24\text{MHz} * \text{N} / \text{M1/M0/P/4}$<br>$7.5 \leq \text{N/M0/M1} \leq 125$ and $12 \leq \text{N}$<br>The working frequency range of $24\text{MHz} * \text{N/M0/M1}$ is from 180 MHz to 3.0 GHz.<br>The default frequency of PLL_AUDIO0PLL1X is 24.5714 MHz. |
| 30             | R/W        | 0x1         | PLL_LDO_EN<br>LDO Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 29             | R/W        | 0x0         | LOCK_ENABLE<br>Lock Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 28             | R          | 0x0         | LOCK                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

| Offset: 0x0078 |            |             | Register Name: PLL_AUDIO0_CTRL_REG                                                                                                          |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                 |
|                |            |             | PLL Lock Info<br>0: Unlocked<br>1: Locked (It indicates that the PLL has been stable.)<br>The bit is only valid when the bit29 is set to 1. |
| 27             | R/W        | 0x1         | PLL_OUTPUT_GATE<br>PLL Output Gating Enable<br>0: Disable<br>1: Enable<br>The bit is used to control the output enable of the PLL.          |
| 26:25          | /          | /           | /                                                                                                                                           |
| 24             | R/W        | 0x0         | PLL_SDM_EN<br>PLL SDM Enable<br>0: Disable<br>1: Enable<br>Enable spread spectrum and decimal division.                                     |
| 23:22          | /          | /           | /                                                                                                                                           |
| 21:16          | R/W        | 0x14        | PLL_P<br>PLL Post Div P<br>$P = \text{PLL\_POST\_DIV\_P} + 1$<br>PLL_POST_DIV_P is from 0 to 63.                                            |
| 15:8           | R/W        | 0x55        | PLL_N<br>PLL N<br>$N = \text{PLL\_N} + 1$<br>PLL_N is from 0 to 254.<br>In application, PLL_N shall be more than or equal to 11.            |
| 7:6            | R/W        | 0x0         | PLL_UNLOCK_MDSEL<br>PLL Unlock Level<br>00: 21-29 Clock Cycles<br>01: 22-28 Clock Cycles<br>1X: 20-30 Clock Cycles                          |
| 5              | R/W        | 0x0         | PLL_LOCK_MDSEL<br>PLL Lock Level<br>0: 24-26 Clock Cycles<br>1: 23-27 Clock Cycles                                                          |
| 4:2            | /          | /           | /                                                                                                                                           |
| 1              | R/W        | 0x0         | PLL_INPUT_DIV2<br>PLL Input Div M1<br>$M1 = \text{PLL\_INPUT\_DIV2} + 1$<br>PLL_INPUT_DIV2 is from 0 to 1.                                  |
| 0              | R/W        | 0x0         | PLL_OUTPUT_DIV2<br>PLL Output Div M0                                                                                                        |

| Offset: 0x0078 |            |             | Register Name: PLL_AUDIO0_CTRL_REG                        |
|----------------|------------|-------------|-----------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                               |
|                |            |             | M0=PLL_OUTPUT_DIV2 + 1<br>PLL_OUTPUT_DIV2 is from 0 to 1. |

#### 2.5.6.11 0x0110 PLL\_DDR Pattern0 Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0110 |            |             | Register Name: PLL_DDR_PAT0_CTRL_REG                                                                                                |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                         |
| 31             | R/W        | 0x0         | SIG_DELT_PAT_EN<br>Sigma Delta Pattern Enable                                                                                       |
| 30:29          | R/W        | 0x0         | SPR_FREQ_MODE<br>Spread Frequency Mode<br>00: pulse swallow<br>01: Triangular(1bit)<br>10: Triangular(2bit)<br>11: Triangular(3bit) |
| 28:20          | R/W        | 0x0         | WAVE_STEP<br>Wave Step                                                                                                              |
| 19             | R/W        | 0x0         | SDM_CLK_SEL<br>SDM Clock Select<br>0: 24MHz<br>1: 12MHz<br>When the PLL_INPUT_DIV2 is 1, the bit needs to be set to 1.              |
| 18:17          | R/W        | 0x0         | FREQ<br>Frequency<br>00: 31.5 kHz<br>01: 32 kHz<br>10: 32.5 kHz<br>11: 33 kHz                                                       |
| 16:0           | R/W        | 0x0         | WAVE_BOT<br>Wave Bottom                                                                                                             |

#### 2.5.6.12 0x0114 PLL\_DDR Pattern1 Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0114 |            |             | Register Name: PLL_DDR_PAT1_CTRL_REG |
|----------------|------------|-------------|--------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                          |
| 31:25          | /          | /           | /                                    |
| 24             | R/W        | 0x0         | DITHER_EN<br>Dither Enable           |
| 23:21          | /          | /           | /                                    |
| 20             | R/W        | 0x0         | FRAC_EN                              |

| Offset: 0x0114 |            |             | Register Name: PLL_DDR_PAT1_CTRL_REG |
|----------------|------------|-------------|--------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                          |
|                |            |             | Fraction Enable                      |
| 19:17          | /          | /           | /                                    |
| 16:0           | R/W        | 0x0         | FRAC_IN<br>Fraction In               |

#### 2.5.6.13 0x0120 PLL\_PERI0 Pattern0 Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0120 |            |             | Register Name: PLL_PERI0_PAT0_CTRL_REG                                                                                              |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                         |
| 31             | R/W        | 0x0         | SIG_DELT_PAT_EN<br>Sigma Delta Pattern Enable                                                                                       |
| 30:29          | R/W        | 0x0         | SPR_FREQ_MODE<br>Spread Frequency Mode<br>00: pulse swallow<br>01: Triangular(1bit)<br>10: Triangular(2bit)<br>11: Triangular(3bit) |
| 28:20          | R/W        | 0x0         | WAVE_STEP<br>Wave Step                                                                                                              |
| 19             | R/W        | 0x0         | SDM_CLK_SEL<br>SDM Clock Select<br>0: 24MHz<br>1: 12MHz<br>When the PLL_INPUT_DIV2 is 1, the bit needs to be set to 1.              |
| 18:17          | R/W        | 0x0         | FREQ<br>Frequency<br>00: 31.5 kHz<br>01: 32 kHz<br>10: 32.5 kHz<br>11: 33 kHz                                                       |
| 16:0           | R/W        | 0x0         | WAVE_BOT<br>Wave Bottom.                                                                                                            |

#### 2.5.6.14 0x0124 PLL\_PERI0 Pattern1 Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0124 |            |             | Register Name: PLL_PERI0_PAT1_CTRL_REG |
|----------------|------------|-------------|----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                            |
| 31:25          | /          | /           | /                                      |
| 24             | R/W        | 0x0         | DITHER_EN<br>Dither Enable             |

| Offset: 0x0124 |            |             | Register Name: PLL_PERI0_PAT1_CTRL_REG |
|----------------|------------|-------------|----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                            |
| 23:21          | /          | /           | /                                      |
| 20             | R/W        | 0x0         | FRAC_EN<br>Fraction Enable             |
| 19:17          | /          | /           | /                                      |
| 16:0           | R/W        | 0x0         | FRAC_IN<br>Fraction In                 |

#### 2.5.6.15 0x0128 PLL\_PERI1 Pattern0 Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0128 |            |             | Register Name: PLL_PERI1_PAT0_CTRL_REG                                                                                              |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                         |
| 31             | R/W        | 0x0         | SIG_DELT_PAT_EN<br>Sigma Delta Pattern Enable                                                                                       |
| 30:29          | R/W        | 0x0         | SPR_FREQ_MODE<br>Spread Frequency Mode<br>00: pulse swallow<br>01: Triangular(1bit)<br>10: Triangular(2bit)<br>11: Triangular(3bit) |
| 28:20          | R/W        | 0x0         | WAVE_STEP<br>Wave Step                                                                                                              |
| 19             | R/W        | 0x0         | SDM_CLK_SEL<br>SDM Clock Select<br>0: 24MHz<br>1: 12MHz<br><br>When the PLL_INPUT_DIV2 is 1, the bit needs to be set to 1.          |
| 18:17          | R/W        | 0x0         | FREQ<br>Frequency<br>00: 31.5 kHz<br>01: 32 kHz<br>10: 32.5 kHz<br>11: 33 kHz                                                       |
| 16:0           | R/W        | 0x0         | WAVE_BOT<br>Wave Bottom                                                                                                             |

#### 2.5.6.16 0x012C PLL\_PERI1 Pattern1 Control Register (Default Value: 0x0000\_0000)

| Offset: 0x012C |            |             | Register Name: PLL_PERI1_PAT1_CTRL_REG |
|----------------|------------|-------------|----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                            |
| 31:25          | /          | /           | /                                      |

| Offset: 0x012C |            |             | Register Name: PLL_PERI1_PAT1_CTRL_REG |
|----------------|------------|-------------|----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                            |
| 24             | R/W        | 0x0         | DITHER_EN<br>Dither Enable             |
| 23:21          | /          | /           | /                                      |
| 20             | R/W        | 0x0         | FRAC_EN<br>Fraction Enable             |
| 19:17          | /          | /           | /                                      |
| 16:0           | R/W        | 0x0         | FRAC_IN<br>Fraction In                 |

#### 2.5.6.17 0x0130 PLL\_GPU Pattern0 Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0130 |            |             | Register Name: PLL_GPU_PAT0_CTRL_REG                                                                                                |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                         |
| 31             | R/W        | 0x0         | SIG_DELT_PAT_EN<br>Sigma Delta Pattern Enable                                                                                       |
| 30:29          | R/W        | 0x0         | SPR_FREQ_MODE<br>Spread Frequency Mode<br>00: pulse swallow<br>01: Triangular(1bit)<br>10: Triangular(2bit)<br>11: Triangular(3bit) |
| 28:20          | R/W        | 0x0         | WAVE_STEP<br>Wave Step                                                                                                              |
| 19             | R/W        | 0x0         | SDM_CLK_SEL<br>SDM Clock Select<br>0: 24MHz<br>1: 12MHz<br>When the PLL_INPUT_DIV2 is 1, the bit needs to be set to 1               |
| 18:17          | R/W        | 0x0         | FREQ<br>Frequency<br>00: 31.5 kHz<br>01: 32 kHz<br>10: 32.5 kHz<br>11: 33 kHz                                                       |
| 16:0           | R/W        | 0x0         | WAVE_BOT<br>Wave Bottom                                                                                                             |

#### 2.5.6.18 0x0134 PLL\_GPU Pattern1 Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0134 | Register Name: PLL_GPU_PAT1_CTRL_REG |
|----------------|--------------------------------------|
|----------------|--------------------------------------|

| Bit   | Read/Write | Default/Hex | Description                |
|-------|------------|-------------|----------------------------|
| 31:25 | /          | /           | /                          |
| 24    | R/W        | 0x0         | DITHER_EN<br>Dither Enable |
| 23:21 | /          | /           | /                          |
| 20    | R/W        | 0x0         | FRAC_EN<br>Fraction Enable |
| 19:17 | /          | /           | /                          |
| 16:0  | R/W        | 0x0         | FRAC_IN<br>Fraction In     |

#### 2.5.6.19 0x0140 PLL\_VIDEO0 Pattern0 Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0140 |            |             | Register Name: PLL_VIDEO0_PAT0_CTRL_REG                                                                                             |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                         |
| 31             | R/W        | 0x0         | SIG_DELT_PAT_EN<br>Sigma Delta Pattern Enable                                                                                       |
| 30:29          | R/W        | 0x0         | SPR_FREQ_MODE<br>Spread Frequency Mode<br>00: pulse swallow<br>01: Triangular(1bit)<br>10: Triangular(2bit)<br>11: Triangular(3bit) |
| 28:20          | R/W        | 0x0         | WAVE_STEP<br>Wave Step                                                                                                              |
| 19             | R/W        | 0x0         | SDM_CLK_SEL<br>SDM Clock Select<br>0: 24MHz<br>1: 12MHz<br>When the PLL_INPUT_DIV2 is 1, the bit needs to be set to 1               |
| 18:17          | R/W        | 0x0         | FREQ<br>Frequency<br>00: 31.5 kHz<br>01: 32 kHz<br>10: 32.5 kHz<br>11: 33 kHz                                                       |
| 16:0           | R/W        | 0x0         | WAVE_BOT<br>Wave Bottom                                                                                                             |

#### 2.5.6.20 0x0144 PLL\_VIDEO0 Pattern1 Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0144 | Register Name: PLL_VIDEO0_PAT1_CTRL_REG |
|----------------|-----------------------------------------|
|----------------|-----------------------------------------|

| Bit   | Read/Write | Default/Hex | Description                |
|-------|------------|-------------|----------------------------|
| 31:25 | /          | /           | /                          |
| 24    | R/W        | 0x0         | DITHER_EN<br>Dither Enable |
| 23:21 | /          | /           | /                          |
| 20    | R/W        | 0x0         | FRAC_EN<br>Fraction Enable |
| 19:17 | /          | /           | /                          |
| 16:0  | R/W        | 0x0         | FRAC_IN<br>Fraction In     |

#### 2.5.6.21 0x0148 PLL\_VIDEO1 Pattern0 Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0148 |            |             | Register Name: PLL_VIDEO1_PAT0_CTRL_REG                                                                                             |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                         |
| 31             | R/W        | 0x0         | SIG_DELT_PAT_EN<br>Sigma Delta Pattern Enable                                                                                       |
| 30:29          | R/W        | 0x0         | SPR_FREQ_MODE<br>Spread Frequency Mode<br>00: pulse swallow<br>01: Triangular(1bit)<br>10: Triangular(2bit)<br>11: Triangular(3bit) |
| 28:20          | R/W        | 0x0         | WAVE_STEP<br>Wave Step                                                                                                              |
| 19             | R/W        | 0x0         | SDM_CLK_SEL<br>SDM Clock Select<br>0: 24MHz<br>1: 12MHz<br>When the PLL_INPUT_DIV2 is 1, the bit needs to be set to 1.              |
| 18:17          | R/W        | 0x0         | FREQ<br>Frequency<br>00: 31.5 kHz<br>01: 32 kHz<br>10: 32.5 kHz<br>11: 33 kHz                                                       |
| 16:0           | R/W        | 0x0         | WAVE_BOT<br>Wave Bottom.                                                                                                            |

#### 2.5.6.22 0x014C PLL\_VIDEO1 Pattern1 Control Register (Default Value: 0x0000\_0000)

| Offset: 0x014C | Register Name: PLL_VIDEO1_PAT1_CTRL_REG |
|----------------|-----------------------------------------|
|----------------|-----------------------------------------|

| Bit   | Read/Write | Default/Hex | Description                |
|-------|------------|-------------|----------------------------|
| 31:25 | /          | /           | /                          |
| 24    | R/W        | 0x0         | DITHER_EN<br>Dither Enable |
| 23:21 | /          | /           | /                          |
| 20    | R/W        | 0x0         | FRAC_EN<br>Fraction Enable |
| 19:17 | /          | /           | /                          |
| 16:0  | R/W        | 0x0         | FRAC_IN<br>Fraction In     |

#### 2.5.6.23 0x0150 PLL\_VIDEO2 Pattern0 Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0150 |            |             | Register Name: PLL_VIDEO2_PAT0_CTRL_REG                                                                                             |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                         |
| 31             | R/W        | 0x0         | SIG_DELT_PAT_EN<br>Sigma Delta Pattern Enable                                                                                       |
| 30:29          | R/W        | 0x0         | SPR_FREQ_MODE<br>Spread Frequency Mode<br>00: pulse swallow<br>01: Triangular(1bit)<br>10: Triangular(2bit)<br>11: Triangular(3bit) |
| 28:20          | R/W        | 0x0         | WAVE_STEP<br>Wave Step                                                                                                              |
| 19             | R/W        | 0x0         | SDM_CLK_SEL<br>SDM Clock Select<br>0: 24MHz<br>1: 12MHz<br>When the PLL_INPUT_DIV2 is 1, the bit needs to be set to 1.              |
| 18:17          | R/W        | 0x0         | FREQ<br>Frequency<br>00: 31.5 kHz<br>01: 32 kHz<br>10: 32.5 kHz<br>11: 33 kHz                                                       |
| 16:0           | R/W        | 0x0         | WAVE_BOT<br>Wave Bottom                                                                                                             |

#### 2.5.6.24 0x0154 PLL\_VIDEO2 Pattern1 Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0154 | Register Name: PLL_VIDEO2_PAT1_CTRL_REG |
|----------------|-----------------------------------------|
|----------------|-----------------------------------------|

| Bit   | Read/Write | Default/Hex | Description                |
|-------|------------|-------------|----------------------------|
| 31:25 | /          | /           | /                          |
| 24    | R/W        | 0x0         | DITHER_EN<br>Dither Enable |
| 23:21 | /          | /           | /                          |
| 20    | R/W        | 0x0         | FRAC_EN<br>Fraction Enable |
| 19:17 | /          | /           | /                          |
| 16:0  | R/W        | 0x0         | FRAC_IN<br>Fraction In     |

#### 2.5.6.25 0x0158 PLL\_VE Pattern0 Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0158 |            |             | Register Name: PLL_VE_PAT0_CTRL_REG                                                                                                 |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                         |
| 31             | R/W        | 0x0         | SIG_DELT_PAT_EN<br>Sigma Delta Pattern Enable                                                                                       |
| 30:29          | R/W        | 0x0         | SPR_FREQ_MODE<br>Spread Frequency Mode<br>00: pulse swallow<br>01: Triangular(1bit)<br>10: Triangular(2bit)<br>11: Triangular(3bit) |
| 28:20          | R/W        | 0x0         | WAVE_STEP<br>Wave Step                                                                                                              |
| 19             | R/W        | 0x0         | SDM_CLK_SEL<br>SDM Clock Select<br>0: 24MHz<br>1: 12MHz<br>When the PLL_INPUT_DIV2 is 1, the bit needs to be set to 1.              |
| 18:17          | R/W        | 0x0         | FREQ<br>Frequency<br>00: 31.5 kHz<br>01: 32 kHz<br>10: 32.5 kHz<br>11: 33 kHz                                                       |
| 16:0           | R/W        | 0x0         | WAVE_BOT<br>Wave Bottom                                                                                                             |

#### 2.5.6.26 0x015C PLL\_VE Pattern1 Control Register (Default Value: 0x0000\_0000)

| Offset: 0x015C | Register Name: PLL_VE_PAT1_CTRL_REG |
|----------------|-------------------------------------|
|----------------|-------------------------------------|

| Bit   | Read/Write | Default/Hex | Description                |
|-------|------------|-------------|----------------------------|
| 31:25 | /          | /           | /                          |
| 24    | R/W        | 0x0         | DITHER_EN<br>Dither Enable |
| 23:21 | /          | /           | /                          |
| 20    | R/W        | 0x0         | FRAC_EN<br>Fraction Enable |
| 19:17 | /          | /           | /                          |
| 16:0  | R/W        | 0x0         | FRAC_IN<br>Fraction In     |

#### 2.5.6.27 0x0168 PLL\_VIDEO3 Pattern0 Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0168 |            |             | Register Name: PLL_VIDEO3_PAT0_CTRL_REG                                                                                             |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                         |
| 31             | R/W        | 0x0         | SIG_DELT_PAT_EN<br>Sigma Delta Pattern Enable                                                                                       |
| 30:29          | R/W        | 0x0         | SPR_FREQ_MODE<br>Spread Frequency Mode<br>00: pulse swallow<br>01: Triangular(1bit)<br>10: Triangular(2bit)<br>11: Triangular(3bit) |
| 28:20          | R/W        | 0x0         | WAVE_STEP<br>Wave Step                                                                                                              |
| 19             | R/W        | 0x0         | SDM_CLK_SEL<br>SDM Clock Select<br>0: 24MHz<br>1: 12MHz<br>When the PLL_INPUT_DIV2 is 1, the bit needs to be set to 1.              |
| 18:17          | R/W        | 0x0         | FREQ<br>Frequency<br>00: 31.5 kHz<br>01: 32 kHz<br>10: 32.5 kHz<br>11: 33 kHz                                                       |
| 16:0           | R/W        | 0x0         | WAVE_BOT<br>Wave Bottom                                                                                                             |

#### 2.5.6.28 0x016C PLL\_VIDEO3 Pattern1 Control Register (Default Value: 0x0000\_0000)

| Offset: 0x016C | Register Name: PLL_VIDEO3_PAT1_CTRL_REG |
|----------------|-----------------------------------------|
|----------------|-----------------------------------------|

| Bit   | Read/Write | Default/Hex | Description                |
|-------|------------|-------------|----------------------------|
| 31:25 | /          | /           | /                          |
| 24    | R/W        | 0x0         | DITHER_EN<br>Dither Enable |
| 23:21 | /          | /           | /                          |
| 20    | R/W        | 0x0         | FRAC_EN<br>Fraction Enable |
| 19:17 | /          | /           | /                          |
| 16:0  | R/W        | 0x0         | FRAC_IN<br>Fraction In     |

#### 2.5.6.29 0x0178 PLL\_AUDIO0 Pattern0 Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0178 |            |             | Register Name: PLL_AUDIO0_PAT0_CTRL_REG                                                                                             |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                         |
| 31             | R/W        | 0x0         | SIG_DELT_PAT_EN<br>Sigma Delta Pattern Enable                                                                                       |
| 30:29          | R/W        | 0x0         | SPR_FREQ_MODE<br>Spread Frequency Mode<br>00: pulse swallow<br>01: Triangular(1bit)<br>10: Triangular(2bit)<br>11: Triangular(3bit) |
| 28:20          | R/W        | 0x0         | WAVE_STEP<br>Wave Step                                                                                                              |
| 19             | R/W        | 0x0         | SDM_CLK_SEL<br>SDM Clock Select<br>0: 24MHz<br>1: 12MHz<br>When the PLL_INPUT_DIV2 is 1, the bit needs to be set to 1.              |
| 18:17          | R/W        | 0x0         | FREQ<br>Frequency<br>00: 31.5 kHz<br>01: 32 kHz<br>10: 32.5 kHz<br>11: 33 kHz                                                       |
| 16:0           | R/W        | 0x0         | WAVE_BOT<br>Wave Bottom                                                                                                             |

#### 2.5.6.30 0x017C PLL\_AUDIO0 Pattern1 Control Register (Default Value: 0x0000\_0000)

| Offset: 0x017C | Register Name: PLL_AUDIO0_PAT1_CTRL_REG |
|----------------|-----------------------------------------|
|----------------|-----------------------------------------|

| Bit   | Read/Write | Default/Hex | Description                |
|-------|------------|-------------|----------------------------|
| 31:25 | /          | /           | /                          |
| 24    | R/W        | 0x0         | DITHER_EN<br>Dither Enable |
| 23:21 | /          | /           | /                          |
| 20    | R/W        | 0x0         | FRAC_EN<br>Fraction Enable |
| 19:17 | /          | /           | /                          |
| 16:0  | R/W        | 0x0         | FRAC_IN<br>Fraction In     |

#### 2.5.6.31 0x0310 PLL\_DDR Bias Register (Default Value: 0x0003\_0000)

| Offset: 0x0310 |            |             | Register Name: PLL_DDR_BIAS_REG |
|----------------|------------|-------------|---------------------------------|
| Bit            | Read/Write | Default/Hex | Description                     |
| 31:21          | /          | /           | /                               |
| 20:16          | R/W        | 0x3         | PLL_CP<br>PLL bias control      |
| 15:0           | /          | /           | /                               |

#### 2.5.6.32 0x0320 PLL\_PERI0 Bias Register (Default Value: 0x0003\_0000)

| Offset: 0x0320 |            |             | Register Name: PLL_PERI0_BIAS_REG |
|----------------|------------|-------------|-----------------------------------|
| Bit            | Read/Write | Default/Hex | Description                       |
| 31:21          | /          | /           | /                                 |
| 20:16          | R/W        | 0x3         | PLL_CP<br>PLL bias control        |
| 15:0           | /          | /           | /                                 |

#### 2.5.6.33 0x0328 PLL\_PERI1 Bias Register (Default Value: 0x0003\_0000)

| Offset: 0x0328 |            |             | Register Name: PLL_PERI1_BIAS_REG |
|----------------|------------|-------------|-----------------------------------|
| Bit            | Read/Write | Default/Hex | Description                       |
| 31:21          | /          | /           | /                                 |
| 20:16          | R/W        | 0x3         | PLL_CP<br>PLL bias control        |
| 15:0           | /          | /           | /                                 |

#### 2.5.6.34 0x0330 PLL\_GPU Bias Register (Default Value: 0x0003\_0000)

| Offset: 0x0330 |  | Register Name: PLL_GPU_BIAS_REG |
|----------------|--|---------------------------------|
|                |  |                                 |

| Bit   | Read/Write | Default/Hex | Description                |
|-------|------------|-------------|----------------------------|
| 31:21 | /          | /           | /                          |
| 20:16 | R/W        | 0x3         | PLL_CP<br>PLL bias control |
| 15:0  | /          | /           | /                          |

#### 2.5.6.35 0x0340 PLL\_VIDEO0 Bias Register (Default Value: 0x0003\_0000)

| Offset: 0x0340 |            |             | Register Name: PLL_VIDEO0_BIAS_REG |
|----------------|------------|-------------|------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                        |
| 31:21          | /          | /           | /                                  |
| 20:16          | R/W        | 0x3         | PLL_CP<br>PLL bias control         |
| 15:0           | /          | /           | /                                  |

#### 2.5.6.36 0x0348 PLL\_VIDEO1 Bias Register (Default Value: 0x0003\_0000)

| Offset: 0x0348 |            |             | Register Name: PLL_VIDEO1_BIAS_REG |
|----------------|------------|-------------|------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                        |
| 31:21          | /          | /           | /                                  |
| 20:16          | R/W        | 0x3         | PLL_CP<br>PLL Bias Control         |
| 15:0           | /          | /           | /                                  |

#### 2.5.6.37 0x0350 PLL\_VIDEO2 Bias Register (Default Value: 0x0003\_0000)

| Offset: 0x0350 |            |             | Register Name: PLL_VIDEO2_BIAS_REG |
|----------------|------------|-------------|------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                        |
| 31:21          | /          | /           | /                                  |
| 20:16          | R/W        | 0x3         | PLL_CP<br>PLL Bias Control         |
| 15:0           | /          | /           | /                                  |

#### 2.5.6.38 0x0358 PLL\_VE Bias Register (Default Value: 0x0003\_0000)

| Offset: 0x0358 |            |             | Register Name: PLL_VE_BIAS_REG |
|----------------|------------|-------------|--------------------------------|
| Bit            | Read/Write | Default/Hex | Description                    |
| 31:21          | /          | /           | /                              |
| 20:16          | R/W        | 0x3         | PLL_CP<br>PLL bias control     |
| 15:0           | /          | /           | /                              |

## 2.5.6.39 0x0368 PLL\_VIDEO3 Bias Register (Default Value: 0x0003\_0000)

| Offset: 0x0368 |            |             | Register Name: PLL_VIDEO3_BIAS_REG |
|----------------|------------|-------------|------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                        |
| 31:21          | /          | /           | /                                  |
| 20:16          | R/W        | 0x3         | PLL_CP<br>PLL bias control         |
| 15:0           | /          | /           | /                                  |

## 2.5.6.40 0x0378 PLL\_AUDIO0 Bias Register (Default Value: 0x0003\_0000)

| Offset: 0x0378 |            |             | Register Name: PLL_AUDIO0_BIAS_REG |
|----------------|------------|-------------|------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                        |
| 31:21          | /          | /           | /                                  |
| 20:16          | R/W        | 0x3         | PLL_CP<br>PLL bias control         |
| 15:0           | /          | /           | /                                  |

## 2.5.6.41 0x0510 AHB Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0510 |            |             | Register Name: AHB_CLK_REG                                                                                                                                                                              |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                             |
| 31:26          | /          | /           | /                                                                                                                                                                                                       |
| 25:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>00: HOSC<br>01: CLK32K<br>10: CLK16M_RC<br>11: PERIO_600M_BUS<br>The clock MUX supports glitch-free switch and dynamic configuration.<br>AHB_CLK = Clock Source/M |
| 23:5           | /          | /           | /                                                                                                                                                                                                       |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M= FACTOR_M +1<br>FACTOR_M is from 0 to 31<br>The clock DIV supports glitch-free switch and dynamic configuration.                                                              |

#### 2.5.6.42 0x0520 APB0 Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0520 |            |             | Register Name: APB0_CLK_REG                                                                                                                                                                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                  |
| 31:26          | /          | /           | /                                                                                                                                                                                                                            |
| 25:24          | R/W        | 0x0         | <p>CLK_SRC_SEL<br/>Clock Source Select<br/>00: HOSC<br/>01: CLK32K<br/>10: CLK16M_RC<br/>11: PERI0_600M_BUS</p> <p>The clock MUX supports glitch-free switch and dynamic configuration.</p> <p>APB0_CLK = Clock Source/M</p> |
| 23:5           | /          | /           | /                                                                                                                                                                                                                            |
| 4:0            | R/W        | 0x0         | <p>FACTOR_M<br/>Factor M<br/>M= FACTOR_M +1<br/>FACTOR_M is from 0 to 31.</p> <p>The clock DIV supports glitch-free switch and dynamic configuration.</p>                                                                    |

#### 2.5.6.43 0x0524 APB1 Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0524 |            |             | Register Name: APB1_CLK_REG                                                                                                                                                                                                                              |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                              |
| 31:27          | /          | /           | /                                                                                                                                                                                                                                                        |
| 26:24          | R/W        | 0x0         | <p>CLK_SRC_SEL<br/>Clock Source Select<br/>000: HOSC<br/>001: CLK32K<br/>010: CLK16M_RC<br/>011: PERI0_600M_BUS<br/>100: PERI0_480M_BUS</p> <p>The clock MUX supports glitch-free switch and dynamic configuration.</p> <p>APB1_CLK = Clock Source/M</p> |
| 23:5           | /          | /           | /                                                                                                                                                                                                                                                        |
| 4:0            | R/W        | 0x0         | <p>FACTOR_M<br/>Factor M<br/>M= FACTOR_M +1<br/>FACTOR_M is from 0 to 31.</p> <p>The clock DIV supports glitch-free switch and dynamic</p>                                                                                                               |

| Offset: 0x0524 |            |             | Register Name: APB1_CLK_REG |
|----------------|------------|-------------|-----------------------------|
| Bit            | Read/Write | Default/Hex | Description                 |
|                |            |             | configuration.              |

#### 2.5.6.44 0x0540 MBUS Clock Register (Default Value: 0xC000\_0000)

| Offset: 0x0540 |            |             | Register Name: MBUS_CLK_REG                                                                                                                                                                                                                                                                              |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                              |
| 31             | R/W        | 0x1         | MBUS_CLK_GATING<br>Gating Special Clock<br>0: Clock is OFF<br>1: Clock is ON<br>MBUS CLK = Clock Source/M                                                                                                                                                                                                |
| 30             | R/W        | 0x1         | MBUS_RST<br>MBUS Reset<br>0: Assert<br>1: De-assert                                                                                                                                                                                                                                                      |
| 29             | /          | /           | /                                                                                                                                                                                                                                                                                                        |
| 28             | R/W        | 0x0         | MBUS_DFS_EN<br>MBUS Clock Dynamic Frequency Scaling Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                                                    |
| 27             | R/WAC      | 0x0         | MBUS_UPD<br>MBUS Clock Configuration 0 update<br>0: Invalid<br>1: Valid<br>Set this bit will validate Configuration 0. It will be auto cleared after the Configuration 0 is valid.<br>This register supports DRAM REQ/ACK signal. When MBUS_UPD is set to 1. MBUS_CLK_SEL and MBUS_CLK1 will be updated. |
| 26:24          | R/W        | 0x0         | MBUS_CLK_SEL<br>Clock Source Select<br>000: DDRPLL<br>001: PERI1_600M<br>010: PERI1_480M<br>011: PERI1_400M<br>100: PERI1_150M<br>101: HOSC<br>The clock MUX supports glitch-free switch and dynamic configuration.                                                                                      |
| 23:5           | /          | /           | /                                                                                                                                                                                                                                                                                                        |
| 4:0            | R/W        | 0x0         | MBUS_DIV1                                                                                                                                                                                                                                                                                                |

| Offset: 0x0540 |            |             | Register Name: MBUS_CLK_REG                                                                                                       |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                       |
|                |            |             | Factor M<br>M= MBUS_DIV1 + 1<br>FACTOR M is from 0 to 31.<br>The clock DIV supports glitch-free switch and dynamic configuration. |

#### 2.5.6.45 0x054C NSI Bus Gating Reset Register (Default Value: 0x0001\_0001)

| Offset: 0x054C |            |             | Register Name: NSI_BGR_REG                        |
|----------------|------------|-------------|---------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                       |
| 31:17          | /          | /           | /                                                 |
| 16             | R/W        | 0x1         | NSI_RST<br>NSI Reset<br>0: Assert<br>1: De-assert |
| 15:0           | /          | /           | /                                                 |

#### 2.5.6.46 0x0550 GIC Clock Register (Default Value: 0x8000\_0000)

| Offset: 0x0550 |            |             | Register Name: GIC_CLK_REG                                                                           |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                          |
| 31             | R/W        | 0x1         | GIC_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>GIC_CLK = Clock Source/M      |
| 30:26          | /          | /           | /                                                                                                    |
| 25:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: HOSC<br>001: CLK32K<br>010: PERIO_600M<br>011: PERIO_480M |
| 23:5           | /          | /           | /                                                                                                    |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M= FACTOR_M +1<br>FACTOR_M is from 0 to 31.                                  |

#### 2.5.6.47 0x0600 DE Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0600 |            |             | Register Name: DE0_CLK_REG                                                                                       |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                      |
| 31             | R/W        | 0x0         | DE_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>DE_CLK = Clock Source/M                    |
| 30:27          | /          | /           | /                                                                                                                |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: PERIO_300M<br>001: PERIO_400M<br>010: VIDEO3PLL4X<br>011: VIDEO3PLL3X |
| 23:5           | /          | /           | /                                                                                                                |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M=FACTOR_M +1<br>FACTOR_M is from 0 to 31.                                               |

#### 2.5.6.48 0x060C DE Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x060C |            |             | Register Name: DE_BGR_REG                              |
|----------------|------------|-------------|--------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                            |
| 31:17          | /          | /           | /                                                      |
| 16             | R/W        | 0x0         | DE_RST<br>DE Reset<br>0: Assert<br>1: De-assert        |
| 15:1           | /          | /           | /                                                      |
| 0              | R/W        | 0x0         | DE_GATING<br>Gating Clock for DE<br>0: Mask<br>1: Pass |

#### 2.5.6.49 0x0620 DI Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0620 |            |             | Register Name: DI_CLK_REG |
|----------------|------------|-------------|---------------------------|
| Bit            | Read/Write | Default/Hex | Description               |
| 31             | R/W        | 0x0         | DI_CLK_GATING             |

| Offset: 0x0620 |            |             | Register Name: DI_CLK_REG                                                                                        |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                      |
|                |            |             | Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>DI_CLK = Clock Source/M                                     |
| 30:27          | /          | /           | /                                                                                                                |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: PERIO_300M<br>001: PERIO_400M<br>010: VIDEO0PLL4X<br>011: VIDEO1PLL4X |
| 23:5           | /          | /           | /                                                                                                                |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M= FACTOR_M +1<br>FACTOR_M is from 0 to 31.                                              |

#### 2.5.6.50 0x062C DI Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x062C |            |             | Register Name: DI_BGR_REG                              |
|----------------|------------|-------------|--------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                            |
| 31:17          | /          | /           | /                                                      |
| 16             | R/W        | 0x0         | DI_RST<br>DI Reset<br>0: Assert<br>1: De-assert        |
| 15:1           | /          | /           | /                                                      |
| 0              | R/W        | 0x0         | DI_GATING<br>Gating Clock for DI<br>0: Mask<br>1: Pass |

#### 2.5.6.51 0x0630 G2D Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0630 |            |             | Register Name: G2D_CLK_REG                                          |
|----------------|------------|-------------|---------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                         |
| 31             | R/W        | 0x0         | G2D_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON |

| Offset: 0x0630 |            |             | Register Name: G2D_CLK_REG                                                                                       |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                      |
|                |            |             | G2D_CLK = Clock Source/M                                                                                         |
| 30:27          | /          | /           | /                                                                                                                |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: PERIO_400M<br>001: PERIO_300M<br>010: VIDEO0PLL4X<br>011: VIDEO1PLL4X |
| 23:5           | /          | /           | /                                                                                                                |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M= FACTOR_M +1<br>FACTOR_M is from 0 to 31.                                              |

#### 2.5.6.52 0x063C G2D Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x063C |            |             | Register Name: G2D_BGR_REG                               |
|----------------|------------|-------------|----------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                              |
| 31:17          | /          | /           | /                                                        |
| 16             | R/W        | 0x0         | G2D_RST<br>G2D Reset<br>0: Assert<br>1: De-assert        |
| 15:1           | /          | /           | /                                                        |
| 0              | R/W        | 0x0         | G2D_GATING<br>Gating Clock for G2D<br>0: Mask<br>1: Pass |

#### 2.5.6.53 0x064C DE\_SYS Bus Gating Reset Register (Default Value: 0x0001\_0000)

| Offset: 0x064C |            |             | Register Name: DE_SYS_BGR_REG                           |
|----------------|------------|-------------|---------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                             |
| 31:17          | /          | /           | /                                                       |
| 16             | R/W        | 0x1         | DE_SYS_RST<br>DE_SYS Reset<br>0: Assert<br>1: De-assert |
| 15:0           | /          | /           | /                                                       |

## 2.5.6.54 0x0670 GPU Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0670 |            |             | Register Name: GPU_CLK_REG                                                                                                                                                                           |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                          |
| 31             | R/W        | 0x0         | GPU_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>GPU_CLK = Clock Source/M                                                                                                      |
| 30:27          | /          | /           | /                                                                                                                                                                                                    |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: GPUPLL<br>001: PERIO_800M<br>010: PERIO_600M<br>011: PERIO_400M<br>100: PERIO_300M<br>101: PERIO_200M<br>The clock selection supports glitch-free switch. |
| 23:4           | /          | /           | /                                                                                                                                                                                                    |
| 3:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>0000: not mask<br>0001: mask 1 cycle at 16 cycles<br>0010: mask 2 cycles at 16 cycles<br>0011: mask 3 cycles at 16 cycles<br>.....<br>1111: mask 15 cycles at 16 cycles      |

## 2.5.6.55 0x067C GPU Gating Reset Configuration Register (Default Value: 0x0000\_0000)

| Offset: 0x067C |            |             | Register Name: GPU_GATING_REG                     |
|----------------|------------|-------------|---------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                       |
| 31:17          | /          | /           | /                                                 |
| 16             | R/W        | 0x0         | GPU_RST<br>GPU Reset<br>0: Assert<br>1: De-assert |
| 15:1           | /          | /           | /                                                 |
| 0              | R/W        | 0x0         | GPU_GATING<br>Gating Clock for GPU<br>0: Mask     |

| Offset: 0x067C |            |             | Register Name: GPU_GATING_REG |
|----------------|------------|-------------|-------------------------------|
| Bit            | Read/Write | Default/Hex | Description                   |
|                |            |             | 1: Pass                       |

#### 2.5.6.56 0x0680 CE Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0680 |            |             | Register Name: CE_CLK_REG                                                                                |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                              |
| 31             | R/W        | 0x0         | CE_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>CE_CLK = Clock Source/M            |
| 30:27          | /          | /           | /                                                                                                        |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: HOSC<br>001: PERIO_480M<br>010: PERIO_400M<br>011: PERIO_300M |
| 23:5           | /          | /           | /                                                                                                        |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M= FACTOR_M +1<br>FACTOR_M is from 0 to 15.                                      |

#### 2.5.6.57 0x068C CE Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x068C |            |             | Register Name: CE_BGR_REG:                              |
|----------------|------------|-------------|---------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                             |
| 31:18          | /          | /           | /                                                       |
| 17             | R/W        | 0x0         | CE_SYS_RST<br>CE_SYS Reset<br>0: Assert<br>1: De-assert |
| 16             | R/W        | 0x0         | CE_RST<br>CE Reset<br>0: Assert<br>1: De-assert         |
| 15:2           | /          | /           | /                                                       |
| 1              | R/W        | 0x0         | CE_SYS_GATING<br>Gating Clock for CE_SYS                |

| Offset: 0x068C |            |             | Register Name: CE_BGR_REG:                             |
|----------------|------------|-------------|--------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                            |
|                |            |             | 0: Mask<br>1: Pass                                     |
| 0              | R/W        | 0x0         | CE_GATING<br>Gating Clock for CE<br>0: Mask<br>1: Pass |

#### 2.5.6.58 0x0690 VE Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0690 |            |             | Register Name: VE_CLK_REG                                                                                 |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                               |
| 31             | R/W        | 0x0         | VE_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>VE_CLK = Clock Source/M             |
| 30:27          | /          | /           | /                                                                                                         |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: VEPLL<br>001: PERIO_480M<br>010: PERIO_400M<br>011: PERIO_300M |
| 23:5           | /          | /           | /                                                                                                         |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M= FACTOR_M +1<br>FACTOR_M is from 0 to 31                                        |

#### 2.5.6.59 0x069C VE Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x069C |            |             | Register Name: VE_BGR_REG                       |
|----------------|------------|-------------|-------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                     |
| 31:17          | /          | /           | /                                               |
| 16             | R/W        | 0x0         | VE_RST<br>VE Reset<br>0: Assert<br>1: De-assert |
| 15:1           | /          | /           | /                                               |
| 0              | R/W        | 0x0         | VE_GATING                                       |

| Offset: 0x069C |            |             | Register Name: VE_BGR_REG                 |
|----------------|------------|-------------|-------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                               |
|                |            |             | Gating Clock for VE<br>0: Mask<br>1: Pass |

#### 2.5.6.60 0x070C DMAC Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x070C |            |             | Register Name: DMAC_BGR_REG                                |
|----------------|------------|-------------|------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                |
| 31:17          | /          | /           | /                                                          |
| 16             | R/W        | 0x0         | DMAC_RST<br>DMAC Reset<br>0: Assert<br>1: De-assert        |
| 15:1           | /          | /           | /                                                          |
| 0              | R/W        | 0x0         | DMAC_GATING<br>Gating Clock for DMAC<br>0: Mask<br>1: Pass |

#### 2.5.6.61 0x071C CPUX\_MSGBOX Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x071C |            |             | Register Name: CPUX_MSGBOX_BGR_REG                                       |
|----------------|------------|-------------|--------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                              |
| 31:17          | /          | /           | /                                                                        |
| 16             | R/W        | 0x0         | CPUX_MSGBOX_RST<br>CPUX_MSGBOX Reset<br>0: Assert<br>1: De-assert        |
| 15:1           | /          | /           | /                                                                        |
| 0              | R/W        | 0x0         | CPUX_MSGBOX_GATING<br>Gating Clock for CPUX_MSGBOX<br>0: Mask<br>1: Pass |

#### 2.5.6.62 0x072C SPINLOCK Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x072C |            |             | Register Name: SPINLOCK_BGR_REG |
|----------------|------------|-------------|---------------------------------|
| Bit            | Read/Write | Default/Hex | Description                     |
| 31:17          | /          | /           | /                               |

| Offset: 0x072C |            |             | Register Name: SPINLOCK_BGR_REG                                    |
|----------------|------------|-------------|--------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                        |
| 16             | R/W        | 0x0         | SPINLOCK_RST<br>SPINLOCK Reset<br>0: Assert<br>1: De-assert        |
| 15:1           | /          | /           | /                                                                  |
| 0              | R/W        | 0x0         | SPINLOCK_GATING<br>Gating Clock for SPINLOCK<br>0: Mask<br>1: Pass |

#### 2.5.6.63 0x0730 CPUX\_TIMER0 Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0730 |            |             | Register Name: CPUX_TIMER0_CLK_REG                                                                                                                                                       |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                              |
| 31             | R/W        | 0x0         | CPUX_TIMER0_CLK_GATING<br>Gating Clock<br>0: Disable<br>1: Enable<br>CPUX_TIMER0_CLK=Clock Source/M                                                                                      |
| 30:27          | /          | /           | /                                                                                                                                                                                        |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: HOSC<br>001: CLK16M_RC<br>010: CLK32K<br>011: PERI0_200M<br>CPUX_TIMER0 clock input, the clock source is 24MHz, RC 16 MHz, 32 kHz, or 200 MHz |
| 23:3           | /          | /           | /                                                                                                                                                                                        |
| 2:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>000: /1<br>001: /2<br>010: /4<br>011: /8<br>100: /16<br>101: /32<br>110: /64<br>111: /128<br>Select the pre-scale of clock source.                               |

## 2.5.6.64 0x0734 CPUX\_TIMER1 Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0734 |            |             | Register Name: CPUX_TIMER1_CLK_REG                                                                                                                                                        |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                               |
| 31             | R/W        | 0x0         | CPUX_TIMER1_CLK_GATING<br>Gating Clock<br>0: Disable<br>1: Enable<br>CPUX_TIMER1_CLK=Clock Source/M                                                                                       |
| 30:27          | /          | /           | /                                                                                                                                                                                         |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: HOSC<br>001: CLK16M_RC<br>010: CLK32K<br>011: PERIO_200M<br>CPUX_TIMER1 clock input, the clock source is 24MHz, RC 16 MHz, 32 kHz, or 200 MHz. |
| 23:3           | /          | /           | /                                                                                                                                                                                         |
| 2:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>000: /1<br>001: /2<br>010: /4<br>011: /8<br>100: /16<br>101: /32<br>110: /64<br>111: /128<br>Select the pre-scale of clock source.                                |

## 2.5.6.65 0x0738 CPUX\_TIMER2 Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0738 |            |             | Register Name: CPUX_TIMER2_CLK_REG                                                                  |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                         |
| 31             | R/W        | 0x0         | CPUX_TIMER2_CLK_GATING<br>Gating Clock<br>0: Disable<br>1: Enable<br>CPUX_TIMER2_CLK=Clock Source/M |
| 30:27          | /          | /           | /                                                                                                   |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select                                                                  |

| Offset: 0x0738 |            |             | Register Name: CPUX_TIMER2_CLK_REG                                                                                                                         |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                |
|                |            |             | 00: HOSC<br>001: CLK16M_RC<br>010: CLK32K<br>011: PERIO_200M<br>CPUX_TIMER2 clock input, the clock source is 24MHz, RC 16 MHz, 32 kHz, or 200 MHz.         |
| 23:3           | /          | /           | /                                                                                                                                                          |
| 2:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>000: /1<br>001: /2<br>010: /4<br>011: /8<br>100: /16<br>101: /32<br>110: /64<br>111: /128<br>Select the pre-scale of clock source. |

#### 2.5.6.66 0x073C CPUX\_TIMER3 Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x073C |            |             | Register Name: CPUX_TIMER3_CLK_REG                                                                                                                                                        |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                               |
| 31             | R/W        | 0x0         | CPUX_TIMER3_CLK_GATING<br>Gating Clock<br>0: Disable<br>1: Enable<br>CPUX_TIMER3_CLK=Clock Source/M                                                                                       |
| 30:27          | /          | /           | /                                                                                                                                                                                         |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: HOSC<br>001: CLK16M_RC<br>010: CLK32K<br>011: PERIO_200M<br>CPUX_TIMER3 clock input, the clock source is 24MHz, RC 16 MHz, 32 kHz, or 200 MHz. |
| 23:3           | /          | /           | /                                                                                                                                                                                         |
| 2:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>000: /1                                                                                                                                                           |

| Offset: 0x073C |            |             | Register Name: CPUX_TIMER3_CLK_REG                                                                                      |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                             |
|                |            |             | 001: /2<br>010: /4<br>011: /8<br>100: /16<br>101: /32<br>110: /64<br>111: /128<br>Select the pre-scale of clock source. |

#### 2.5.6.67 0x0740 CPUX\_TIMER4 Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0740 |            |             | Register Name: CPUX_TIMER4_CLK_REG                                                                                                                                                        |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                               |
| 31             | R/W        | 0x0         | CPUX_TIMER4_CLK_GATING<br>Gating Clock<br>0: Disable<br>1: Enable<br>CPUX_TIMER4_CLK=Clock Source/M                                                                                       |
| 30:27          | /          | /           | /                                                                                                                                                                                         |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: HOSC<br>001: CLK16M_RC<br>010: CLK32K<br>011: PERIO_200M<br>CPUX_TIMER4 clock input, the clock source is 24MHz, RC 16 MHz, 32 kHz, or 200 MHz. |
| 23:3           | /          | /           | /                                                                                                                                                                                         |
| 2:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>000: /1<br>001: /2<br>010: /4<br>011: /8<br>100: /16<br>101: /32<br>110: /64<br>111: /128<br>Select the pre-scale of clock source.                                |

## 2.5.6.68 0x0744 CPUX\_TIMER5 Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0744 |            |             | Register Name: CPUX_TIMER5_CLK_REG                                                                                                                                                        |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                               |
| 31             | R/W        | 0x0         | CPUX_TIMER5_CLK_GATING<br>Gating Clock<br>0: Disable<br>1: Enable<br>CPUX_TIMER5_CLK=Clock Source/M                                                                                       |
| 30:27          | /          | /           | /                                                                                                                                                                                         |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: HOSC<br>001: CLK16M_RC<br>010: CLK32K<br>011: PERIO_200M<br>CPUX_TIMER5 clock input, the clock source is 24MHz, RC 16 MHz, 32 kHz, or 200 MHz. |
| 23:3           | /          | /           | /                                                                                                                                                                                         |
| 2:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>000: /1<br>001: /2<br>010: /4<br>011: /8<br>100: /16<br>101: /32<br>110: /64<br>111: /128<br>Select the pre-scale of clock source.                                |

## 2.5.6.69 0x074C CPUX\_TIMER Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x074C |            |             | Register Name: CPUX_TIMER_BGR_REG                                |
|----------------|------------|-------------|------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                      |
| 31:17          | /          | /           | /                                                                |
| 16             | R/W        | 0x0         | CPUX_TIMER_RST.<br>CPUX_TIMER Reset<br>0: Assert<br>1: De-assert |
| 15:1           | /          | /           | /                                                                |
| 0              | R/W        | 0x0         | CPUX_TIMER_GATING.                                               |

| Offset: 0x074C |            |             | Register Name: CPUX_TIMER_BGR_REG                 |
|----------------|------------|-------------|---------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                       |
|                |            |             | Gating Clock for CPUX_TIMER<br>0: Mask<br>1: Pass |

#### 2.5.6.70 0x078C DBGSYS Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x078C |            |             | Register Name: DBGSYS_BGR_REG                                  |
|----------------|------------|-------------|----------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                    |
| 31:17          | /          | /           | /                                                              |
| 16             | R/W        | 0x0         | DBGSYS_RST<br>DBGSYS Reset<br>0: Assert<br>1: De-assert        |
| 15:1           | /          | /           | /                                                              |
| 0              | R/W        | 0x0         | DBGSYS_GATING<br>Gating Clock for DBGSYS<br>0: Mask<br>1: Pass |

#### 2.5.6.71 0x07AC PWMCTRL Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x07AC |            |             | Register Name: PWMCTRL_BGR_REG                                     |
|----------------|------------|-------------|--------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                        |
| 31:18          | /          | /           | /                                                                  |
| 17             | R/W        | 0x0         | PWMCTRL1_RST<br>PWMCTRL1 Reset<br>0: Assert<br>1: De-assert        |
| 16             | R/W        | 0x0         | PWMCTRL0_RST<br>PWMCTRL0 Reset<br>0: Assert<br>1: De-assert        |
| 15:2           | /          | /           | /                                                                  |
| 1              | R/W        | 0x0         | PWMCTRL1_GATING<br>Gating Clock for PWMCTRL1<br>0: Mask<br>1: Pass |
| 0              | R/W        | 0x0         | PWMCTRL0_GATING<br>Gating Clock for PWMCTRL0<br>0: Mask            |

| Offset: 0x07AC |            |             | Register Name: PWMCTRL_BGR_REG |
|----------------|------------|-------------|--------------------------------|
| Bit            | Read/Write | Default/Hex | Description                    |
|                |            |             | 1: Pass                        |

#### 2.5.6.72 0x07B0 IOMMU Clock Register (Default Value: 0x8000\_0000)

| Offset: 0x07B0 |            |             | Register Name: IOMMU_CLK_REG                                                                                                                                                                                                                                                                                  |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                   |
| 31             | R/W        | 0x1         | IOMMU_CLK_GATING<br>Gating Special Clock<br>0: Clock is OFF<br>1: Clock is ON<br>IOMMU_CLK = Clock Source/M                                                                                                                                                                                                   |
| 30:29          | /          | /           | /                                                                                                                                                                                                                                                                                                             |
| 28             | R/W        | 0x0         | IOMMU_DFS_EN<br>IOMMU CLK Dynamic Frequency Scaling Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                                                         |
| 27             | R/WAC      | 0x0         | IOMMU_UPD<br>IOMMU Clock Configuration 0 update<br>0: Invalid<br>1: Valid<br>Set this bit will validate Configuration 0. It will be auto cleared after the Configuration 0 is valid.<br>This register supports DRAM REQ/ACK signal. When IOMMU_UPD is set to 1. IOMMU_CLK_SEL and IOMMU_CLK1 will be updated. |
| 26:24          | R/W        | 0x0         | IOMMU_CLK_SEL<br>Clock Source Select<br>000: PERI0_600M<br>001: DDRPLL<br>010: PERI1_480M<br>011: PERI1_400M<br>100: PERI1_150M<br>101: HOSC<br>The clock MUX supports glitch-free switch and dynamic configuration.                                                                                          |
| 23:5           | /          | /           | /                                                                                                                                                                                                                                                                                                             |
| 4:0            | R/W        | 0x0         | IOMMU_DIV1<br>Factor M<br>M= IOMMU_DIV1 + 1<br>FACTOR M is from 0 to 31.<br>The clock DIV supports glitch-free switch and dynamic                                                                                                                                                                             |

| Offset: 0x07B0 |            |             | Register Name: IOMMU_CLK_REG |
|----------------|------------|-------------|------------------------------|
| Bit            | Read/Write | Default/Hex | Description                  |
|                |            |             | configuration.               |

#### 2.5.6.73 0x07BC IOMMU Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x07BC |            |             | Register Name: IOMMU_BGR_REG                                 |
|----------------|------------|-------------|--------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                  |
| 31:1           | /          | /           | /                                                            |
| 0              | R/W        | 0x0         | IOMMU_GATING<br>Gating Clock for IOMMU<br>0: Mask<br>1: Pass |

#### 2.5.6.74 0x0800 DRAM Clock Register (Default Value: 0x8000\_0000)

| Offset: 0x0800 |            |             | Register Name: DRAM_CLK_REG                                                                                                                                                                                                                                                                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                  |
| 31             | R/W        | 0x1         | DRAM_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>DRAM_CLK = Clock Source/M                                                                                                                                                                                                                            |
| 30:28          | /          | /           | /                                                                                                                                                                                                                                                                                                                            |
| 27             | R/WAC      | 0x0         | DRAM_UPD<br>SDRCLK Configuration 0 update<br>0: Invalid<br>1: Valid<br>Note: Set this bit will validate Configuration 0. It will be auto cleared after the Configuration 0 is valid.<br>This register supports DRAM REQ/ACK signal. When DRAM_UPD is set to 1, DRAM_CLK_GATING, DRAM_CLK_SEL, and DRAM_DIV1 will be updated. |
| 26:24          | R/W        | 0x0         | DRAM_CLK_SEL<br>Clock Source Select<br>000: DDRPLL<br>001: PERI1_600M<br>010: PERI1_480M<br>011: PERI1_400M<br>100: PERI1_150M<br>The clock MUX supports glitch-free switch and dynamic configuration.                                                                                                                       |

| Offset: 0x0800 |            |             | Register Name: DRAM_CLK_REG                                                                                                                    |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                    |
| 23:5           | /          | /           | /                                                                                                                                              |
| 4:0            | R/W        | 0x0         | DRAM_DIV1<br>Factor M<br>M= DRAM_DIV1 + 1<br>FACTOR M is from 0 to 31.<br>The clock DIV supports glitch-free switch and dynamic configuration. |

#### 2.5.6.75 0x0804 MBUS Master Clock Gating Register (Default Value: 0x03D7\_0000)

| Offset: 0x0804 |            |             | Register Name: MBUS_MAT_CLK_GATING_REG                                               |
|----------------|------------|-------------|--------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                          |
| 31:26          | /          | /           | /                                                                                    |
| 25             | R/W        | 0x1         | USB_SYS_MBUS_GATE_SW_CFG<br>USB_SYS MBUS Clock Gate Enable<br>0: Disable<br>1:Enable |
| 24             | R/W        | 0x1         | GPU_MBUS_GATE_SW_CFG<br>GPU MBUS Clock Gate Enable<br>0: Disable<br>1:Enable         |
| 23             | R/W        | 0x1         | DE_SYS_MBUS_GATE_SW_CFG<br>DE_SYS MBUS Clock Gate Enable<br>0: Disable<br>1:Enable   |
| 22             | R/W        | 0x1         | NDFC_MBUS_GATE_SW_CFG<br>NDFC MBUS Clock Gate Enable<br>0: Disable<br>1:Enable       |
| 21             | /          | /           | /                                                                                    |
| 20             | R/W        | 0x1         | VID_IN_MBUS_GATE_SW_CFG<br>VID_IN MBUS Clock Gate Enable<br>0: Disable<br>1:Enable   |
| 19             | /          | /           | /                                                                                    |
| 18             | R/W        | 0x1         | CE_MBUS_GATE_SW_CFG<br>CE MBUS Clock Gate Enable<br>0: Disable<br>1:Enable           |
| 17             | R/W        | 0x1         | VE_MBUS_GATE_SW_CFG                                                                  |

| Offset: 0x0804 |            |             | Register Name: MBUS_MAT_CLK_GATING_REG                                         |
|----------------|------------|-------------|--------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                    |
|                |            |             | VE MBUS Clock Gate Enable<br>0: Disable<br>1:Enable                            |
| 16             | R/W        | 0x1         | DMAC_MBUS_GATE_SW_CFG<br>DMAC MBUS Clock Gate Enable<br>0: Disable<br>1:Enable |
| 15:10          | /          | /           | /                                                                              |
| 9              | R/W        | 0x0         | ISP_MCLK_EN<br>Gating MBUS Clock for ISP<br>0: Mask<br>1: Pass                 |
| 8              | R/W        | 0x0         | CSI_MCLK_EN<br>Gating MBUS Clock for CSI<br>0: Mask<br>1: Pass                 |
| 7              | /          | /           | /                                                                              |
| 6              | R/W        | 0x0         | USB3_MCLK_EN<br>Gating MBUS Clock for USB3<br>0: Mask<br>1: Pass               |
| 5              | R/W        | 0x0         | NDFC_MCLK_EN<br>Gating MBUS Clock for NDFC<br>0: Mask<br>1: Pass               |
| 4:3            | /          | /           | /                                                                              |
| 2              | R/W        | 0x0         | CE_MCLK_EN<br>Gating MBUS Clock for CE<br>0: Mask<br>1: Pass                   |
| 1              | R/W        | 0x0         | VE_MCLK_EN<br>Gating MBUS Clock for VE<br>0: Mask<br>1: Pass                   |
| 0              | R/W        | 0x0         | DMAC_MCLK_EN<br>Gating MBUS Clock for DMAC<br>0: Mask<br>1: Pass               |

## 2.5.6.76 0x080C DRAM Bus Gating Reset Register (Default Value: 0x0000\_0001)

| Offset: 0x080C |            |             | Register Name: DRAM_BGR_REG                                |
|----------------|------------|-------------|------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                |
| 31:17          | /          | /           | /                                                          |
| 16             | R/W        | 0x0         | DRAM_RST<br>DRAM Reset<br>0: Assert<br>1: De-assert        |
| 15:1           | /          | /           | /                                                          |
| 0              | R/W        | 0x1         | DRAM_GATING<br>Gating Clock for DRAM<br>0: Mask<br>1: Pass |

## 2.5.6.77 0x0810 NDFC CLK0 Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0810 |            |             | Register Name: NDFC_CLK0_CLK_REG                                                                                            |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                 |
| 31             | R/W        | 0x0         | NDFC_CLK0_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>NDFC_CLK0_CLK = Clock Source/M                 |
| 30:27          | /          | /           | /                                                                                                                           |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: HOSC<br>001: PERI0_400M<br>010: PERI0_300M<br>011: PERI1_400M<br>100: PERI1_300M |
| 23:5           | /          | /           | /                                                                                                                           |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M= FACTOR_M +1<br>FACTOR_M is from 0 to 15.                                                         |

## 2.5.6.78 0x0814 NDFC CLK1 Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0814 |            |             | Register Name: NDFC_CLK1_CLK_REG |
|----------------|------------|-------------|----------------------------------|
| Bit            | Read/Write | Default/Hex | Description                      |

| Offset: 0x0814 |            |             | Register Name: NDFC_CLK1_CLK_REG                                                                                            |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                 |
| 31             | R/W        | 0x0         | NDFC_CLK1_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>NDFC_CLK1_CLK = Clock Source/M                 |
| 30:27          | /          | /           | /                                                                                                                           |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: HOSC<br>001: PERI0_400M<br>010: PERI0_300M<br>011: PERI1_400M<br>100: PERI1_300M |
| 23:5           | /          | /           | /                                                                                                                           |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M= FACTOR_M +1<br>FACTOR_M is from 0 to 15.                                                         |

#### 2.5.6.79 0x082C NDFC Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x082C |            |             | Register Name: NDFC_BGR_REG                                |
|----------------|------------|-------------|------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                |
| 31:17          | /          | /           | /                                                          |
| 16             | R/W        | 0x0         | NDFC_RST<br>NDFC Reset<br>0: Assert<br>1: De-assert        |
| 15:1           | /          | /           | /                                                          |
| 0              | R/W        | 0x0         | NDFC_GATING<br>Gating Clock for NDFC<br>0: Mask<br>1: Pass |

#### 2.5.6.80 0x0830 SMHC0 Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0830 |            |             | Register Name: SMHC0_CLK_REG     |
|----------------|------------|-------------|----------------------------------|
| Bit            | Read/Write | Default/Hex | Description                      |
| 31             | R/W        | 0x0         | SMHC0_CLK_GATING<br>Gating Clock |

| Offset: 0x0830 |            |             | Register Name: SMHC0_CLK_REG                                                                                                |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                 |
|                |            |             | 0: Clock is OFF<br>1: Clock is ON<br>SMHC0_CLK = Clock Source/M/N                                                           |
| 30:27          | /          | /           | /                                                                                                                           |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: HOSC<br>001: PERI0_400M<br>010: PERI0_300M<br>011: PERI1_400M<br>100: PERI1_300M |
| 23:13          | /          | /           | /                                                                                                                           |
| 12:8           | R/W        | 0x0         | FACTOR_N<br>Factor N<br>N=FACTOR_N +1<br>FACTOR_N is from 0 to 31.                                                          |
| 7:5            | /          | /           | /                                                                                                                           |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M=FACTOR_M +1<br>FACTOR_M is from 0 to 31.                                                          |

#### 2.5.6.81 0x0834 SMHC1 Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0834 |            |             | Register Name: SMHC1_CLK_REG                                                                                                |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                 |
| 31             | R/W        | 0x0         | SMHC1_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>SMHC1_CLK = Clock Source/M/N                       |
| 30:27          | /          | /           | /                                                                                                                           |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: HOSC<br>001: PERI0_400M<br>010: PERI0_300M<br>011: PERI1_400M<br>100: PERI1_300M |
| 23:13          | /          | /           | /                                                                                                                           |

| Offset: 0x0834 |            |             | Register Name: SMHC1_CLK_REG                                       |
|----------------|------------|-------------|--------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                        |
| 12:8           | R/W        | 0x0         | FACTOR_N<br>Factor N<br>N=FACTOR_N +1<br>FACTOR_N is from 0 to 31. |
| 7:5            | /          | /           | /                                                                  |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M=FACTOR_M +1<br>FACTOR_M is from 0 to 31. |

#### 2.5.6.82 0x0838 SMHC2 Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0838 |            |             | Register Name: SMHC2_CLK_REG                                                                                                |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                 |
| 31             | R/W        | 0x0         | SMHC2_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>SMHC2_CLK = Clock Source/M/N                       |
| 30:27          | /          | /           | /                                                                                                                           |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: HOSC<br>001: PERI0_800M<br>010: PERI0_600M<br>011: PERI1_800M<br>100: PERI1_600M |
| 23:13          | /          | /           | /                                                                                                                           |
| 12:8           | R/W        | 0x0         | FACTOR_N<br>Factor N<br>N=FACTOR_N +1<br>FACTOR_N is from 0 to 31.                                                          |
| 7:5            | /          | /           | /                                                                                                                           |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M=FACTOR_M +1<br>FACTOR_M is from 0 to 31.                                                          |

## 2.5.6.83 0x084C SMHC Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x084C |            |             | Register Name: SMHC_BGR_REG                                  |
|----------------|------------|-------------|--------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                  |
| 31:19          | /          | /           | /                                                            |
| 18             | R/W        | 0x0         | SMHC2_RST<br>SMHC2 Reset<br>0: Assert<br>1: De-assert        |
| 17             | R/W        | 0x0         | SMHC1_RST<br>SMHC1 Reset<br>0: Assert<br>1: De-assert        |
| 16             | R/W        | 0x0         | SMHC0_RST<br>SMHC0 Reset<br>0: Assert<br>1: De-assert        |
| 15:3           | /          | /           | /                                                            |
| 2              | R/W        | 0x0         | SMHC2_GATING<br>Gating Clock for SMHC2<br>0: Mask<br>1: Pass |
| 1              | R/W        | 0x0         | SMHC1_GATING<br>Gating Clock for SMHC1<br>0: Mask<br>1: Pass |
| 0              | R/W        | 0x0         | SMHC0_GATING<br>Gating Clock for SMHC0<br>0: Mask<br>1: Pass |

## 2.5.6.84 0x088C SYSDAP Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x088C |            |             | Register Name: SYSDAP_BGR_REG                           |
|----------------|------------|-------------|---------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                             |
| 31:17          | /          | /           | /                                                       |
| 16             | R/W        | 0x0         | SYSDAP_RST<br>SYSDAP Reset<br>0: Assert<br>1: De-assert |
| 15:1           | /          | /           | /                                                       |
| 0              | R/W        | 0x0         | SYSDAP_GATING                                           |

| Offset: 0x088C |            |             | Register Name: SYSDAP_BGR_REG               |
|----------------|------------|-------------|---------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                 |
|                |            |             | Gating Clock for DRAM<br>0: Mask<br>1: Pass |

#### 2.5.6.85 0x090C UART Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x090C |            |             | Register Name: UART_BGR_REG                           |
|----------------|------------|-------------|-------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                           |
| 31:24          | /          | /           | /                                                     |
| 23             | R/W        | 0x0         | UART7_RST<br>UART7 Reset<br>0: Assert<br>1: De-assert |
| 22             | R/W        | 0x0         | UART6_RST<br>UART6 Reset<br>0: Assert<br>1: De-assert |
| 21             | R/W        | 0x0         | UART5_RST<br>UART5 Reset<br>0: Assert<br>1: De-assert |
| 20             | R/W        | 0x0         | UART4_RST<br>UART4 Reset<br>0: Assert<br>1: De-assert |
| 19             | R/W        | 0x0         | UART3_RST<br>UART3 Reset<br>0: Assert<br>1: De-assert |
| 18             | R/W        | 0x0         | UART2_RST<br>UART2 Reset<br>0: Assert<br>1: De-assert |
| 17             | R/W        | 0x0         | UART1_RST<br>UART1 Reset<br>0: Assert<br>1: De-assert |
| 16             | R/W        | 0x0         | UART0_RST<br>UART0 Reset<br>0: Assert<br>1: De-assert |

| Offset: 0x090C |            |             | Register Name: UART_BGR_REG                                  |
|----------------|------------|-------------|--------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                  |
| 15:8           | /          | /           | /                                                            |
| 7              | R/W        | 0x0         | UART7_GATING<br>Gating Clock for UART7<br>0: Mask<br>1: Pass |
| 6              | R/W        | 0x0         | UART6_GATING<br>Gating Clock for UART6<br>0: Mask<br>1: Pass |
| 5              | R/W        | 0x0         | UART5_GATING<br>Gating Clock for UART5<br>0: Mask<br>1: Pass |
| 4              | R/W        | 0x0         | UART4_GATING<br>Gating Clock for UART4<br>0: Mask<br>1: Pass |
| 3              | R/W        | 0x0         | UART3_GATING<br>Gating Clock for UART3<br>0: Mask<br>1: Pass |
| 2              | R/W        | 0x0         | UART2_GATING<br>Gating Clock for UART2<br>0: Mask<br>1: Pass |
| 1              | R/W        | 0x0         | UART1_GATING<br>Gating Clock for UART1<br>0: Mask<br>1: Pass |
| 0              | R/W        | 0x0         | UART0_GATING<br>Gating Clock for UART0<br>0: Mask<br>1: Pass |

#### 2.5.6.86 0x091C TWI Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x091C |            |             | Register Name: TWI_BGR_REG |
|----------------|------------|-------------|----------------------------|
| Bit            | Read/Write | Default/Hex | Description                |
| 31:22          | /          | /           | /                          |
| 21             | R/W        | 0x0         | TWI5_RST<br>TWI5 Reset     |

| Offset: 0x091C |            |             | Register Name: TWI_BGR_REG                                 |
|----------------|------------|-------------|------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                |
|                |            |             | 0: Assert<br>1: De-assert                                  |
| 20             | R/W        | 0x0         | TWI4_RST<br>TWI4 Reset<br>0: Assert<br>1: De-assert        |
| 19             | R/W        | 0x0         | TWI3_RST<br>TWI3 Reset<br>0: Assert<br>1: De-assert        |
| 18             | R/W        | 0x0         | TWI2_RST<br>TWI2 Reset<br>0: Assert<br>1: De-assert        |
| 17             | R/W        | 0x0         | TWI1_RST<br>TWI1 Reset<br>0: Assert<br>1: De-assert        |
| 16             | R/W        | 0x0         | TWI0_RST<br>TWI0 Reset<br>0: Assert<br>1: De-assert        |
| 15:6           | /          | /           | /                                                          |
| 5              | R/W        | 0x0         | TWI5_GATING<br>Gating Clock for TWI5<br>0: Mask<br>1: Pass |
| 4              | R/W        | 0x0         | TWI4_GATING<br>Gating Clock for TWI4<br>0: Mask<br>1: Pass |
| 3              | R/W        | 0x0         | TWI3_GATING<br>Gating Clock for TWI3<br>0: Mask<br>1: Pass |
| 2              | R/W        | 0x0         | TWI2_GATING<br>Gating Clock for TWI2<br>0: Mask<br>1: Pass |
| 1              | R/W        | 0x0         | TWI1_GATING<br>Gating Clock for TWI1                       |

| Offset: 0x091C |            |             | Register Name: TWI_BGR_REG                                 |
|----------------|------------|-------------|------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                |
|                |            |             | 0: Mask<br>1: Pass                                         |
| 0              | R/W        | 0x0         | TWI0_GATING<br>Gating Clock for TWI0<br>0: Mask<br>1: Pass |

#### 2.5.6.87 0x0940 SPI0 Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0940 |            |             | Register Name: SPI0_CLK_REG                                                                                                 |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                 |
| 31             | R/W        | 0x0         | SPI0_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>SPI0_CLK = Clock Source/M/N                         |
| 30:27          | /          | /           | /                                                                                                                           |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: HOSC<br>001: PERI0_300M<br>010: PERI0_200M<br>011: PERI1_300M<br>100: PERI1_200M |
| 23:13          | /          | /           | /                                                                                                                           |
| 12:8           | R/W        | 0x0         | FACTOR_N<br>Factor N<br>N= FACTOR_N +1<br>FACTOR_N is from 0 to 31.                                                         |
| 7:5            | /          | /           | /                                                                                                                           |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M= FACTOR_M +1<br>FACTOR_M is from 0 to 31.                                                         |

#### 2.5.6.88 0x0944 SPI1 Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0944 |            |             | Register Name: SPI1_CLK_REG |
|----------------|------------|-------------|-----------------------------|
| Bit            | Read/Write | Default/Hex | Description                 |
| 31             | R/W        | 0x0         | SPI1_CLK_GATING             |

| Offset: 0x0944 |            |             | Register Name: SPI1_CLK_REG                                                                                                 |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                 |
|                |            |             | Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>SPI1_CLK = Clock Source/M/N                                            |
| 30:27          | /          | /           | /                                                                                                                           |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: HOSC<br>001: PERI0_300M<br>010: PERI0_200M<br>011: PERI1_300M<br>100: PERI1_200M |
| 23:13          | /          | /           | /                                                                                                                           |
| 12:8           | R/W        | 0x0         | FACTOR_N<br>Factor N<br>N= FACTOR_N +1<br>FACTOR_N is from 0 to 31.                                                         |
| 7:5            | /          | /           | /                                                                                                                           |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M= FACTOR_M +1<br>FACTOR_M is from 0 to 31.                                                         |

#### 2.5.6.89 0x0948 SPI2 Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0948 |            |             | Register Name: SPI2_CLK_REG                                                                                                 |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                 |
| 31             | R/W        | 0x0         | SPI2_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>SPI2_CLK = Clock Source/M/N                         |
| 30:27          | /          | /           | /                                                                                                                           |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: HOSC<br>001: PERI0_300M<br>010: PERI0_200M<br>011: PERI1_300M<br>100: PERI1_200M |
| 23:13          | /          | /           | /                                                                                                                           |

| Offset: 0x0948 |            |             | Register Name: SPI2_CLK_REG                                         |
|----------------|------------|-------------|---------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                         |
| 12:8           | R/W        | 0x0         | FACTOR_N<br>Factor N<br>N= FACTOR_N +1<br>FACTOR_N is from 0 to 31. |
| 7:5            | /          | /           | /                                                                   |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M= FACTOR_M +1<br>FACTOR_M is from 0 to 31. |

#### 2.5.6.90 0x0950 SPIFC Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0950 |            |             | Register Name: SPIFC_CLK_REG                                                                                                |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                 |
| 31             | R/W        | 0x0         | SPIFC_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>SPIFC_CLK = Clock Source/M/N                       |
| 30:27          | /          | /           | /                                                                                                                           |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: HOSC<br>001: PERI0_400M<br>010: PERI0_300M<br>011: PERI1_400M<br>100: PERI1_300M |
| 23:13          | /          | /           | /                                                                                                                           |
| 12:8           | R/W        | 0x0         | FACTOR_N<br>Factor N<br>N= FACTOR_N +1<br>FACTOR_N is from 0 to 31.                                                         |
| 7:5            | /          | /           | /                                                                                                                           |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M= FACTOR_M +1<br>FACTOR_M is from 0 to 31.                                                         |

## 2.5.6.91 0x096C SPI Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x096C |            |             | Register Name: SPI_BGR_REG                                   |
|----------------|------------|-------------|--------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                  |
| 31:20          | /          | /           | /                                                            |
| 19             | R/W        | 0x0         | SPIFC_RST<br>SPIFC Reset<br>0: Assert<br>1: De-assert        |
| 18             | R/W        | 0x0         | SPI2_RST<br>SPI2 Reset<br>0: Assert<br>1: De-assert          |
| 17             | R/W        | 0x0         | SPI1_RST<br>SPI1 Reset<br>0: Assert<br>1: De-assert          |
| 16             | R/W        | 0x0         | SPI0_RST<br>SPI0 Reset<br>0: Assert<br>1: De-assert          |
| 15:4           | /          | /           | /                                                            |
| 3              | R/W        | 0x0         | SPIFC_GATING<br>Gating Clock for SPIFC<br>0: Mask<br>1: Pass |
| 2              | R/W        | 0x0         | SPI2_GATING<br>Gating Clock for SPI2<br>0: Mask<br>1: Pass   |
| 1              | R/W        | 0x0         | SPI1_GATING<br>Gating Clock for SPI1<br>0: Mask<br>1: Pass   |
| 0              | R/W        | 0x0         | SPI0_GATING<br>Gating Clock for SPI0<br>0: Mask<br>1: Pass   |

## 2.5.6.92 0x0970 GMAC\_25M Clock Register (Default Value: 0x0000\_0000)

|                |                                 |
|----------------|---------------------------------|
| Offset: 0x0970 | Register Name: GMAC_25M_CLK_REG |
|----------------|---------------------------------|

| Bit  | Read/Write | Default/Hex | Description                                                                                                  |
|------|------------|-------------|--------------------------------------------------------------------------------------------------------------|
| 31   | R/W        | 0x0         | GMAC_25M_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>GMAC_25M_CLK = PERI0_150M/6=25M  |
| 30   | R/W        | 0x0         | GMAC_25M_CLK_SRC_GATING<br>Gating the Source Clock for Low Power Design<br>0: Clock is OFF<br>1: Clock is ON |
| 29:0 | /          | /           | /                                                                                                            |

#### 2.5.6.93 0x097C GMAC Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x097C |            |             | Register Name: GMAC_BGR_REG                                |
|----------------|------------|-------------|------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                |
| 31:17          | /          | /           | /                                                          |
| 16             | R/W        | 0x0         | GMAC_RST<br>GMAC Reset<br>0: Assert<br>1: De-assert        |
| 15:1           | /          | /           | /                                                          |
| 0              | R/W        | 0x0         | GMAC_GATING<br>Gating Clock for GMAC<br>0: Mask<br>1: Pass |

#### 2.5.6.94 0x0990 IRRX Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0990 |            |             | Register Name: IRRX_CLK_REG                                                                       |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                       |
| 31             | R/W        | 0x0         | IRRX_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>IRRX_CLK = Clock Source/M |
| 30:25          | /          | /           | /                                                                                                 |
| 24             | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>0: CLK32K<br>1: HOSC                                        |
| 23:5           | /          | /           | /                                                                                                 |

| Offset: 0x0990 |            |             | Register Name: IRRX_CLK_REG                                         |
|----------------|------------|-------------|---------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                         |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M= FACTOR_M +1<br>FACTOR_M is from 0 to 31. |

#### 2.5.6.95 0x099C IRRX Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x099C |            |             | Register Name: IRRX_BGR_REG                                |
|----------------|------------|-------------|------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                |
| 31:17          | /          | /           | /                                                          |
| 16             | R/W        | 0x0         | IRRX_RST<br>IRRX Reset<br>0: Assert<br>1: De-assert        |
| 15:1           | /          | /           | /                                                          |
| 0              | R/W        | 0x0         | IRRX_GATING<br>Gating Clock for IRRX<br>0: Mask<br>1: Pass |

#### 2.5.6.96 0x09C0 IRTX Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x09C0 |            |             | Register Name: IRTX_CLK_REG                                                                       |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                       |
| 31             | R/W        | 0x0         | IRTX_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>IRTX_CLK = Clock Source/M |
| 30:27          | /          | /           | /                                                                                                 |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>0: HOSC<br>1: PERI1_600M                                    |
| 23:5           | /          | /           | /                                                                                                 |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M= FACTOR_M +1<br>FACTOR_M is from 0 to 31.                               |

## 2.5.6.97 0x09CC IRTX Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x09CC |            |             | Register Name: IRTX_BGR_REG                                |
|----------------|------------|-------------|------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                |
| 31:17          | /          | /           | /                                                          |
| 16             | R/W        | 0x0         | IRTX_RST<br>IRTX Reset<br>0: Assert<br>1: De-assert        |
| 15:1           | /          | /           | /                                                          |
| 0              | R/W        | 0x0         | IRTX_GATING<br>Gating Clock for IRTX<br>0: Mask<br>1: Pass |

## 2.5.6.98 0x09E0 GPADC\_24M Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x09E0 |            |             | Register Name: GPADC_24M_CLK_REG                                                                  |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                       |
| 31             | R/W        | 0x0         | GPADC_24M_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>GPADC_24M_CLK = HOSC |
| 30:5           | /          | /           | /                                                                                                 |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M= FACTOR_M +1<br>FACTOR_M is from 0 to 31                                |

## 2.5.6.99 0x09EC GPADC Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x09EC |            |             | Register Name: GPADC_BGR_REG                          |
|----------------|------------|-------------|-------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                           |
| 31:17          | /          | /           | /                                                     |
| 16             | R/W        | 0x0         | GPADC_RST<br>GPADC Reset<br>0: Assert<br>1: De-assert |
| 15:1           | /          | /           | /                                                     |
| 0              | R/W        | 0x0         | GPADC_GATING<br>Gating Clock for GPADC                |

| Offset: 0x09EC |            |             | Register Name: GPADC_BGR_REG |
|----------------|------------|-------------|------------------------------|
| Bit            | Read/Write | Default/Hex | Description                  |
|                |            |             | 0: Mask<br>1: Pass           |

#### 2.5.6.100 0x09FC THS Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x09FC |            |             | Register Name: THS_BGR_REG                               |
|----------------|------------|-------------|----------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                              |
| 31:17          | /          | /           | /                                                        |
| 16             | R/W        | 0x0         | THS_RST<br>THS Reset<br>0: Assert<br>1: De-assert        |
| 15:1           | /          | /           | /                                                        |
| 0              | R/W        | 0x0         | THS_GATING<br>Gating Clock for THS<br>0: Mask<br>1: Pass |

#### 2.5.6.101 0x0A70 USB0 Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0A70 |            |             | Register Name: USB0_CLK_REG                                                                                                          |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                          |
| 31             | R/W        | 0x0         | USB0_CLKEN<br>Gating Clock for OHCI0<br>0: Clock is OFF<br>1: Clock is ON                                                            |
| 30             | R/W        | 0x0         | USBPHY0_RSTN<br>USB PHY0 Reset<br>0: Assert<br>1: De-assert                                                                          |
| 29:26          | /          | /           | /                                                                                                                                    |
| 25:24          | R/W        | 0x0         | USB0_CLK12M_SEL<br>OHCI0 12M Source Select<br>00: 12M divided from 48MHz<br>01: 12M divided from HOSC<br>10: CLK32K<br>11: CLK16M_RC |
| 23:0           | /          | /           | /                                                                                                                                    |

#### 2.5.6.102 0x0A74 USB1 Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0A74 |            |             | Register Name: USB1_CLK_REG                                                                                                          |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                          |
| 31             | R/W        | 0x0         | USB1_CLKEN<br>Gating Clock for OHCI1<br>0: Clock is OFF<br>1: Clock is ON                                                            |
| 30             | R/W        | 0x0         | USBPHY1_RSTN<br>USB PHY1 Reset<br>0: Assert<br>1: De-assert                                                                          |
| 29:26          | /          | /           | /                                                                                                                                    |
| 25:24          | R/W        | 0x0         | USB1_CLK12M_SEL<br>OHCI1 12M Source Select<br>00: 12M divided from 48MHz<br>01: 12M divided from HOSC<br>10: CLK32K<br>11: CLK16M_RC |
| 23:0           | /          | /           | /                                                                                                                                    |

#### 2.5.6.103 0x0A80 USB2\_REF Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0A80 |            |             | Register Name: USB2_REF_CLK_REG                                                                 |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                     |
| 31             | R/W        | 0x0         | USB2_REF_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>USB2_REF_CLK = HOSC |
| 30:0           | /          | /           | /                                                                                               |

#### 2.5.6.104 0x0A84 USB3\_PCIE\_REF Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0A84 |            |             | Register Name: USB3_PCIE_REF_CLK_REG                                                                         |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                  |
| 31             | R/W        | 0x0         | USB3_PCIE_REF_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>USB3_REF_CLK = Clock Source |
| 30:27          | /          | /           | /                                                                                                            |

| Offset: 0x0A84 |            |             | Register Name: USB3_PCIE_REF_CLK_REG                                               |
|----------------|------------|-------------|------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                        |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>00: HOSC<br>01: PERIO_200M<br>10: PERI1_200M |
| 23:5           | /          | /           | /                                                                                  |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M= FACTOR_M +1<br>FACTOR_M is from 0 to 31.                |

#### 2.5.6.105 0x0A88 USB3\_SUSPEND Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0A88 |            |             | Register Name: USB3_SUSPEND_CLK_REG                                                                               |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                       |
| 31             | R/W        | 0x0         | USB3_SUSPEND_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>USB3_SUSPEND_CLK = Clock Source/M |
| 30:25          | /          | /           | /                                                                                                                 |
| 24             | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>0: CLK32K<br>1: HOSC                                                        |
| 23:5           | /          | /           | /                                                                                                                 |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M= FACTOR_M +1<br>FACTOR_M is from 0 to 31.                                               |

#### 2.5.6.106 0x0A8C USB Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x0A8C |            |             | Register Name: USB_BGR_REG                                      |
|----------------|------------|-------------|-----------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                     |
| 31:25          | /          | /           | /                                                               |
| 24             | R/W        | 0x0         | USBDEVICE0_RST<br>USBDEVICE0 Reset<br>0: Assert<br>1: De-assert |

| Offset: 0x0A8C |            |             | Register Name: USB_BGR_REG                                             |
|----------------|------------|-------------|------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                            |
| 23:22          | /          | /           | /                                                                      |
| 21             | R/W        | 0x0         | USBEHCI1_RST<br>USBEHCI1 Reset<br>0: Assert<br>1: De-assert            |
| 20             | R/W        | 0x0         | USBEHCI0_RST<br>USBEHCI0 Reset<br>0: Assert<br>1: De-assert            |
| 19:18          | /          | /           | /                                                                      |
| 17             | R/W        | 0x0         | USBOHCI1_RST<br>USBOHCI1 Reset<br>0: Assert<br>1: De-assert            |
| 16             | R/W        | 0x0         | USBOHCI0_RST<br>USBOHCI0 Reset<br>0: Assert<br>1: De-assert            |
| 15:9           | /          | /           | /                                                                      |
| 8              | R/W        | 0x0         | USBDEVICE0_GATING<br>Gating Clock for USBDEVICE0<br>0: Mask<br>1: Pass |
| 7:6            | /          | /           | /                                                                      |
| 5              | R/W        | 0x0         | USBEHCI1_GATING<br>Gating Clock for USBEHCI1<br>0: Mask<br>1: Pass     |
| 4              | R/W        | 0x0         | USBEHCI0_GATING<br>Gating Clock for USBEHCI0<br>0: Mask<br>1: Pass     |
| 3:2            | /          | /           | /                                                                      |
| 1              | R/W        | 0x0         | USBOHCI1_GATING<br>Gating Clock for USBOHCI1<br>0: Mask<br>1: Pass     |
| 0              | R/W        | 0x0         | USBOHCI0_GATING<br>Gating Clock for USBOHCI0<br>0: Mask<br>1: Pass     |

#### 2.5.6.107 0x0A9C LRADC Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x0A9C |            |             | Register Name: LRADC_BGR_REG                                 |
|----------------|------------|-------------|--------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                  |
| 31:17          | /          | /           | /                                                            |
| 16             | R/W        | 0x0         | LRADC_RST<br>LRADC Reset<br>0: Assert<br>1: De-assert        |
| 15:1           | /          | /           | /                                                            |
| 0              | R/W        | 0x0         | LRADC_GATING<br>Gating Clock for LRADC<br>0: Mask<br>1: Pass |

#### 2.5.6.108 0x0AA0 PCIE\_AUX Clock Register (Default Value: 0x8000\_0000)

| Offset: 0x0AA0 |            |             | Register Name: PCIE_AUX_CLK_REG                                                                               |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                   |
| 31             | R/W        | 0x1         | PCIE_AUX_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>PCIE_REF_ALT_CLK = Clock Source/M |
| 30:25          | /          | /           | /                                                                                                             |
| 24             | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>0: HOSC<br>1: CLK32K                                                    |
| 23:5           | /          | /           | /                                                                                                             |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M= FACTOR_M +1<br>FACTOR_M is from 0 to 31.                                           |

#### 2.5.6.109 0x0AAC PCIE Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x0AAC |            |             | Register Name: PCIE_BGR_REG              |
|----------------|------------|-------------|------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                              |
| 31:17          | /          | /           | /                                        |
| 16             | R/W        | 0x0         | PCIE_USB3_SYS_RST<br>PCIE POWER_UP Reset |

| Offset: 0x0AAC |            |             | Register Name:PCIE_BGR_REG |
|----------------|------------|-------------|----------------------------|
| Bit            | Read/Write | Default/Hex | Description                |
|                |            |             | 0: Assert<br>1: De-assert  |
| 15:0           | /          | /           | /                          |

#### 2.5.6.110 0x0ABC DISPLAY0\_TOP Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x0ABC |            |             | Register Name: DISPLAY0_TOP_BGR_REG                                        |
|----------------|------------|-------------|----------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                |
| 31:17          | /          | /           | /                                                                          |
| 16             | R/W        | 0x0         | DISPLAY0_TOP_RST<br>DISPLAY0_TOP Reset<br>0: Assert<br>1: De-assert        |
| 15:1           | /          | /           | /                                                                          |
| 0              | R/W        | 0x0         | DISPLAY0_TOP_GATING<br>Gating Clock for DISPLAY0_TOP<br>0: Mask<br>1: Pass |

#### 2.5.6.111 0x0B24 DSI0 Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0B24 |            |             | Register Name: DSI0_CLK_REG                                                                       |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                       |
| 31             | R/W        | 0x0         | DSI0_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>DSI0_CLK = Clock Source/M |
| 30:27          | /          | /           | /                                                                                                 |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: HOSC<br>001: PERIO_200M<br>010: PERIO_150M             |
| 23:5           | /          | /           | /                                                                                                 |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M= FACTOR_M +1<br>FACTOR_M is from 0 to 31.                               |

### 2.5.6.112 0x0B28 DSI1 Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0B28 |            |             | Register Name: DSI1_CLK_REG                                                                       |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                       |
| 31             | R/W        | 0x0         | DSI1_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>DSI1_CLK = Clock Source/M |
| 30:27          | /          | /           | /                                                                                                 |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: HOSC<br>001: PERIO_200M<br>010: PERIO_150M             |
| 23:5           | /          | /           | /                                                                                                 |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M= FACTOR_M +1<br>FACTOR_M is from 0 to 31.                               |

### 2.5.6.113 0x0B4C DSI Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x0B4C |            |             | Register Name: DSI_BGR_REG                                 |
|----------------|------------|-------------|------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                |
| 31:18          | /          | /           | /                                                          |
| 17             | R/W        | 0x0         | DSI1_RST<br>DSI1 Reset<br>0: Assert<br>1: De-assert        |
| 16             | R/W        | 0x0         | DSI0_RST<br>DSI0 Reset<br>0: Assert<br>1: De-assert        |
| 15:2           | /          | /           | /                                                          |
| 1              | R/W        | 0x0         | DSI1_GATING<br>Gating Clock for DSI1<br>0: Mask<br>1: Pass |
| 0              | R/W        | 0x0         | DSI0_GATING<br>Gating Clock for DSI0<br>0: Mask            |

| Offset: 0x0B4C |            |             | Register Name: DSI_BGR_REG |
|----------------|------------|-------------|----------------------------|
| Bit            | Read/Write | Default/Hex | Description                |
|                |            |             | 1: Pass                    |

#### 2.5.6.114 0x0B60 TCONLCD0 Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0B60 |            |             | Register Name: TCONLCD0_CLK_REG:                                                                                                                                             |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                  |
| 31             | R/W        | 0x0         | TCONLCD0_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>TCONLCD0_CLK = Clock Source/M                                                                    |
| 30:27          | /          | /           | /                                                                                                                                                                            |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: VIDEO0PLL4X<br>001: VIDEO1PLL4X<br>010: VIDEO2PLL4X<br>011: VIDEO3PLL4X<br>100: PERI0PLL2X<br>101: VIDEO0PLL3X<br>110:VIDEO1PLL3X |
| 23:5           | /          | /           | /                                                                                                                                                                            |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M= FACTOR_M +1<br>FACTOR_M is from 0 to 31.                                                                                                          |

#### 2.5.6.115 0x0B64 TCONLCD1 Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0B64 |            |             | Register Name: TCONLCD1_CLK_REG                                                                           |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                               |
| 31             | R/W        | 0x0         | TCONLCD1_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>TCONLCD1_CLK = Clock Source/M |
| 30:27          | /          | /           | /                                                                                                         |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: VIDEO0PLL4X                                                    |

| Offset: 0x0B64 |            |             | Register Name: TCONLCD1_CLK_REG                                                                                    |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                        |
|                |            |             | 001: VIDEO1PLL4X<br>010: VIDEO2PLL4X<br>011: VIDEO3PLL4X<br>100: PERI0PLL2X<br>101: VIDEO0PLL3X<br>110:VIDEO1PLL3X |
| 23:5           | /          | /           | /                                                                                                                  |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M= FACTOR_M +1<br>FACTOR_M is from 0 to 15.                                                |

#### 2.5.6.116 0xB6C COMBOPHY\_DSI0 Clock Register (Default Value: 0x0000\_0000)

| Offset: 0xB6C |            |             | Register Name: COMBOPHY_DSI0_CLK_REG                                                                                                                                         |
|---------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                                  |
| 31            | R/W        | 0x0         | COMBOPHY_DSI0_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>COMBOPHY_DSI0_CLK = Clock Source/M                                                          |
| 30:27         | /          | /           | /                                                                                                                                                                            |
| 26:24         | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: VIDEO0PLL4X<br>001: VIDEO1PLL4X<br>010: VIDEO2PLL4X<br>011: VIDEO3PLL4X<br>100: PERI0PLL2X<br>101: VIDEO0PLL3X<br>110:VIDEO1PLL3X |
| 23:5          | /          | /           | /                                                                                                                                                                            |
| 4:0           | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M= FACTOR_M +1<br>FACTOR_M is from 0 to 31.                                                                                                          |

#### 2.5.6.117 0xB70 COMBOPHY\_DSI1 Clock Register (Default Value: 0x0000\_0000)

|               |                                      |
|---------------|--------------------------------------|
| Offset: 0xB70 | Register Name: COMBOPHY_DSI1_CLK_REG |
|---------------|--------------------------------------|

| Bit   | Read/Write | Default/Hex | Description                                                                                                                                                                  |
|-------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | R/W        | 0x0         | COMBOPHY_DSI1_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>COMBOPHY_DSI1_CLK = Clock Source/M                                                          |
| 30:27 | /          | /           | /                                                                                                                                                                            |
| 26:24 | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: VIDEO0PLL4X<br>001: VIDEO1PLL4X<br>010: VIDEO2PLL4X<br>011: VIDEO3PLL4X<br>100: PERI0PLL2X<br>101: VIDEO0PLL3X<br>110:VIDEO1PLL3X |
| 23:5  | /          | /           | /                                                                                                                                                                            |
| 4:0   | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M= FACTOR_M +1<br>FACTOR_M is from 0 to 31.                                                                                                          |

#### 2.5.6.118 0x0B7C TCONLCD Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x0B7C |            |             | Register Name: TCONLCD_BGR_REG                                      |
|----------------|------------|-------------|---------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                         |
| 31:18          | /          | /           | /                                                                   |
| 17             | R/W        | 0x0         | TCONLCD1_RST<br>TCON LCD1 Reset<br>0: Assert<br>1: De-assert        |
| 16             | R/W        | 0x0         | TCONLCD0_RST<br>TCON LCD0 Reset<br>0: Assert<br>1: De-assert        |
| 15:2           | /          | /           | /                                                                   |
| 1              | R/W        | 0x0         | TCONLCD1_GATING<br>Gating Clock for TCON LCD1<br>0: Mask<br>1: Pass |
| 0              | R/W        | 0x0         | TCONLCD0_GATING<br>Gating Clock for TCON LCD0<br>0: Mask            |

| Offset: 0x0B7C |            |             | Register Name: TCONLCD_BGR_REG |
|----------------|------------|-------------|--------------------------------|
| Bit            | Read/Write | Default/Hex | Description                    |
|                |            |             | 1: Pass                        |

#### 2.5.6.119 0x0B84 TCONTV1 Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0B84 |            |             | Register Name: TCONTV1_CLK_REG                                                                                                        |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                           |
| 31             | R/W        | 0x0         | TCONTV1_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>TCONTV1_CLK = Clock Source/M                               |
| 30:27          | /          | /           | /                                                                                                                                     |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: VIDEO0PLL4X<br>001: VIDEO1PLL4X<br>010: VIDEO2PLL4X<br>011: VIDEO3PLL4X<br>100: PERI0PLL2X |
| 23:5           | /          | /           | /                                                                                                                                     |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M=FACTOR_M +1<br>FACTOR_M is from 0 to 31                                                                     |

#### 2.5.6.120 0x0B9C TCONTV Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x0B9C |            |             | Register Name: TCONTV_BGR_REG                                    |
|----------------|------------|-------------|------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                      |
| 31:18          | /          | /           | /                                                                |
| 17             | R/W        | 0x0         | TCONTV1_RST<br>TCONTV1 Reset<br>0: Assert<br>1: De-assert        |
| 16:2           | /          | /           | /                                                                |
| 1              | R/W        | 0x0         | TCONTV1_GATING<br>Gating Clock for TCONTV1<br>0: Mask<br>1: Pass |
| 0              | /          | /           | /                                                                |

#### 2.5.6.121 0x0BAC LVDS Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x0BAC |            |             | Register Name: LVDS_BGR_REG                           |
|----------------|------------|-------------|-------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                           |
| 31:17          | /          | /           | /                                                     |
| 16             | R/W        | 0x0         | LVDS0_RST<br>LVDS0 Reset<br>0: Assert<br>1: De-assert |
| 15:0           | /          | /           | /                                                     |

#### 2.5.6.122 0x0BB0 EDP Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0BB0 |            |             | Register Name: EDP_CLK_REG                                                                                                            |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                           |
| 31             | R/W        | 0x0         | EDP_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>EDP_CLK = Clock Source/M                                       |
| 30:27          | /          | /           | /                                                                                                                                     |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: VIDEO0PLL4X<br>001: VIDEO1PLL4X<br>010: VIDEO2PLL4X<br>011: VIDEO3PLL4X<br>100: PERIOPLL2X |
| 23:5           | /          | /           | /                                                                                                                                     |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M= FACTOR_M +1<br>FACTOR_M is from 0 to 31.                                                                   |

#### 2.5.6.123 0x0BBC EDP Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x0BBC |            |             | Register Name: EDP_BGR_REG        |
|----------------|------------|-------------|-----------------------------------|
| Bit            | Read/Write | Default/Hex | Description                       |
| 31:17          | /          | /           | /                                 |
| 16             | R/W        | 0x0         | EDP_RST<br>EDP Reset<br>0: Assert |

| Offset: 0x0BBC |            |             | Register Name: EDP_BGR_REG                               |
|----------------|------------|-------------|----------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                              |
|                |            |             | 1: De-assert                                             |
| 15:1           | /          | /           | /                                                        |
| 0              | R/W        | 0x0         | EDP_GATING<br>Gating Clock for EDP<br>0: Mask<br>1: Pass |

#### 2.5.6.124 0x0BCC Video Out Bus Gating Reset Register (Default Value: 0x0003\_0000)

| Offset: 0x0BCC |            |             | Register Name: VIDEO_OUT_BGR_REG                                |
|----------------|------------|-------------|-----------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                     |
| 31:17          | /          | /           | /                                                               |
| 16             | R/W        | 0x1         | VIDEO_OUT0_RST<br>VIDEO_OUT0 Reset<br>0: Assert<br>1: De-assert |
| 15:0           | /          | /           | /                                                               |

#### 2.5.6.125 0x0BF0 LEDC Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0BF0 |            |             | Register Name: LEDC_CLK_REG                                                                         |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                         |
| 31             | R/W        | 0x0         | LEDC_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>LEDC_CLK = Clock Source/M/N |
| 30:25          | /          | /           | /                                                                                                   |
| 24             | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: HOSC<br>001: PERIO_600M                                  |
| 23:5           | /          | /           | /                                                                                                   |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M=FACTOR_M +1<br>FACTOR_M is from 0 to 31                                   |

#### 2.5.6.126 0x0BFC LEDC Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x0BFC |            |             | Register Name: LEDC_BGR_REG                                |
|----------------|------------|-------------|------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                |
| 31:17          | /          | /           | /                                                          |
| 16             | R/W        | 0x0         | LEDC_RST<br>LEDC Reset<br>0: Assert<br>1: De-assert        |
| 15:1           | /          | /           | /                                                          |
| 0              | R/W        | 0x0         | LEDC_GATING<br>Gating Clock for LEDC<br>0: Mask<br>1: Pass |

#### 2.5.6.127 0x0C04 CSI Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0C04 |            |             | Register Name: CSI_CLK_REG                                                                                                          |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                         |
| 31             | R/W        | 0x0         | CSI_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>CSI_CLK = Clock Source/M                                     |
| 30:27          | /          | /           | /                                                                                                                                   |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: PERIO_300M<br>001: PERIO_400M<br>010: PERIO_480M<br>011: VIDEO3PLL4X<br>100: VIDEO3PLL3X |
| 23:5           | /          | /           | /                                                                                                                                   |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M=FACTOR_M +1<br>FACTOR_M is from 0 to 31                                                                   |

#### 2.5.6.128 0x0C08 CSI Master0 Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0C08 |            |             | Register Name: CSI_MASTER0_CLK_REG |
|----------------|------------|-------------|------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                        |

| Offset: 0x0C08 |            |             | Register Name: CSI_MASTER0_CLK_REG                                                                                             |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                    |
| 31             | R/W        | 0x0         | CSI_MASTER0_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>CSI_MASTER0_CLK = Clock Source/M/N              |
| 30:27          | /          | /           | /                                                                                                                              |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: HOSC<br>001: VIDEO3PLL4X<br>010: VIDEO0PLL4X<br>011: VIDEO1PLL4X<br>100:VIDEO2PLL4X |
| 23:13          | /          | /           | /                                                                                                                              |
| 12:8           | R/W        | 0x0         | FACTOR_N<br>Factor N<br>N= FACTOR_N +1<br>FACTOR_N is from 0 to 31.                                                            |
| 7:5            | /          | /           | /                                                                                                                              |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M= FACTOR_M +1<br>FACTOR_M is from 0 to 31                                                             |

#### 2.5.6.129 0x0C0C CSI Master1 Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0C0C |            |             | Register Name: CSI_MASTER1_CLK_REG                                                                                             |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                    |
| 31             | R/W        | 0x0         | CSI_MASTER1_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>CSI_MASTER1_CLK = Clock Source/M/N              |
| 30:27          | /          | /           | /                                                                                                                              |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: HOSC<br>001: VIDEO3PLL4X<br>010: VIDEO0PLL4X<br>011: VIDEO1PLL4X<br>100:VIDEO2PLL4X |

| Offset: 0x0C0C |            |             | Register Name: CSI_MASTER1_CLK_REG                                 |
|----------------|------------|-------------|--------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                        |
| 23:13          | /          | /           | /                                                                  |
| 12:8           | R/W        | 0x0         | FACTOR_N<br>Factor N<br>N= FACTOR_N +1<br>FACTOR_N is from 0 to 31 |
| 7:5            | /          | /           | /                                                                  |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M= FACTOR_M +1<br>FACTOR_M is from 0 to 31 |

#### 2.5.6.130 0x0C10 CSI Master2 Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0C10 |            |             | Register Name: CSI_MASTER2_CLK_REG                                                                                             |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                    |
| 31             | R/W        | 0x0         | CSI_MASTER2_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>CSI_MASTER2_CLK = Clock Source/M/N              |
| 30:27          | /          | /           | /                                                                                                                              |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: HOSC<br>001: VIDEO3PLL4X<br>010: VIDEO0PLL4X<br>011: VIDEO1PLL4X<br>100:VIDEO2PLL4X |
| 23:13          | /          | /           | /                                                                                                                              |
| 12:8           | R/W        | 0x0         | FACTOR_N<br>Factor N<br>N= FACTOR_N +1<br>FACTOR_N is from 0 to 31                                                             |
| 7:5            | /          | /           | /                                                                                                                              |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M= FACTOR_M +1<br>FACTOR_M is from 0 to 31                                                             |

## 2.5.6.131 0x0C14 CSI Master3 Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0C14 |            |             | Register Name: CSI_MASTER3_CLK_REG                                                                                             |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                    |
| 31             | R/W        | 0x0         | CSI_MASTER3_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>CSI_MASTER3_CLK = Clock Source/M/N              |
| 30:27          | /          | /           | /                                                                                                                              |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: HOSC<br>001: VIDEO3PLL4X<br>010: VIDEO0PLL4X<br>011: VIDEO1PLL4X<br>100:VIDEO2PLL4X |
| 23:13          | /          | /           | /                                                                                                                              |
| 12:8           | R/W        | 0x0         | FACTOR_N<br>Factor N<br>N= FACTOR_N +1<br>FACTOR_N is from 0 to 31                                                             |
| 7:5            | /          | /           | /                                                                                                                              |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M= FACTOR_M +1<br>FACTOR_M is from 0 to 31                                                             |

## 2.5.6.132 0x0C1C CSI Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x0C1C |            |             | Register Name: CSI_BGR_REG                               |
|----------------|------------|-------------|----------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                              |
| 31:17          | /          | /           | /                                                        |
| 16             | R/W        | 0x0         | CSI_RST<br>CSI Reset<br>0: Assert<br>1: De-assert        |
| 15:1           | /          | /           | /                                                        |
| 0              | R/W        | 0x0         | CSI_GATING<br>Gating Clock for CSI<br>0: Mask<br>1: Pass |

## 2.5.6.133 0x0C20 ISP Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0C20 |            |             | Register Name: ISP_CLK_REG                                                                                       |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                      |
| 31             | R/W        | 0x0         | ISP_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>ISP_CLK = Clock Source/M                  |
| 30:27          | /          | /           | /                                                                                                                |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: PERIO_300M<br>001: PERIO_400M<br>010: VIDEO2PLL4X<br>011: VIDEO3PLL4X |
| 23:5           | /          | /           | /                                                                                                                |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M= FACTOR_M +1<br>FACTOR_M is from 0 to 31                                               |

## 2.5.6.134 0x0E04 AHB Gate Enable Register (Default Value: 0x107F\_0FFE)

| Offset: 0x0E04 |            |             | Register Name: AHB_GATE_EN_REG                                                                                         |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                            |
| 31             | R/W        | 0x0         | AHB_MONITOR_EN<br>AHB bus auto clock gating function enable<br>1: enable auto clock gate<br>0: disable auto clock gate |
| 30             | /          | /           | /                                                                                                                      |
| 29             | R/W        | 0x0         | SD_MONITOR_EN<br>SD bus auto clock gating function enable<br>1: enable auto clock gate<br>0: disable auto clock gate   |
| 28             | R/W        | 0x1         | CPUS_HCLK_GATE_SW_CFG<br>CPUS AHB Clock Gate Enable<br>0: Disable<br>1:Enable                                          |
| 27:23          | /          | /           | /                                                                                                                      |
| 22             | R/W        | 0x1         | SPIFC_MBUS_AHB_GATE_SW_CFG<br>SPIFC MBUS_AHB Clock Gate Enable                                                         |

| Offset: 0x0E04 |            |             | Register Name: AHB_GATE_EN_REG                                                            |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                               |
|                |            |             | 0: Disable<br>1: Enable                                                                   |
| 21             | /          | /           | /                                                                                         |
| 20             | R/W        | 0x1         | GMAC_MBUS_AHB_GATE_SW_CFG<br>GMAC MBUS_AHB Clock Gate Enable<br>0: Disable<br>1: Enable   |
| 19             | R/W        | 0x1         | SMHC2_MBUS_AHB_GATE_SW_CFG<br>SMHC2 MBUS_AHB Clock Gate Enable<br>0: Disable<br>1: Enable |
| 18             | R/W        | 0x1         | SMHC1_MBUS_AHB_GATE_SW_CFG<br>SMHC1 MBUS_AHB Clock Gate Enable<br>0: Disable<br>1: Enable |
| 17             | R/W        | 0x1         | SMHC0_MBUS_AHB_GATE_SW_CFG<br>SMHC0 MBUS_AHB Clock Gate Enable<br>0: Disable<br>1: Enable |
| 16             | R/W        | 0x1         | USB_MBUS_AHB_GATE_SW_CFG<br>USB MBUS_AHB Clock Gate Enable<br>0: Disable<br>1: Enable     |
| 15:12          | /          | /           | /                                                                                         |
| 11             | R/W        | 0x1         | USB_SYS_AHB_GATE_SW_CFG<br>USB_SYS AHB Clock Gate Enable<br>0: Disable<br>1: Enable       |
| 10             | R/W        | 0x1         | GPU_AHB_GATE_SW_CFG<br>GPU AHB Clock Gate Enable<br>0: Disable<br>1: Enable               |
| 9              | /          | /           | /                                                                                         |
| 8              | R/W        | 0x1         | GMAC_AHB_GATE_SW_CFG<br>GMAC AHB Clock Gate Enable<br>0: Disable<br>1: Enable             |
| 7              | R/W        | 0x1         | SMHC2_AHB_GATE_SW_CFG<br>SMHC2 AHB Clock Gate Enable<br>0: Disable<br>1: Enable           |

| Offset: 0x0E04 |            |             | Register Name: AHB_GATE_EN_REG                                                        |
|----------------|------------|-------------|---------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                           |
| 6              | R/W        | 0x1         | SMHC1_AHB_GATE_SW_CFG<br>SMHC1 AHB Clock Gate Enable<br>0: Disable<br>1: Enable       |
| 5              | R/W        | 0x1         | SMHC0_AHB_GATE_SW_CFG<br>SMHC0 AHB Clock Gate Enable<br>0: Disable<br>1: Enable       |
| 4              | R/W        | 0x1         | USB_AHB_GATE_SW_CFG<br>USB AHB Clock Gate Enable<br>0: Disable<br>1: Enable           |
| 3              | R/W        | 0x1         | VID_OUT_AHB_GATE_SW_CFG<br>Video Out AHB Clock Gate Enable<br>0: Disable<br>1: Enable |
| 2              | R/W        | 0x1         | VID_IN_AHB_GATE_SW_CFG<br>Video in AHB Clock Gate Enable<br>0: Disable<br>1: Enable   |
| 1              | R/W        | 0x1         | VE_AHB_GATE_SW_CFG<br>VE AHB Clock Gate Enable<br>0: Disable<br>1: Enable             |
| 0              | /          | /           | /                                                                                     |

#### 2.5.6.135 0xE08 PERIOPLL Gate Enable Register (Default Value: 0xFFFF\_0FFF)

| Offset: 0x0E08 |            |             | Register Name: PERIOPLL_GATE_EN_REG:                                              |
|----------------|------------|-------------|-----------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                       |
| 31:28          | /          | /           | /                                                                                 |
| 27             | R/W        | 0x1         | PERIOPLL2X_GATE_SW_CFG<br>PERIOPLL2X Clock Gate Enable<br>0: Disable<br>1: Enable |
| 26             | R/W        | 0x1         | PERIO_800M_GATE_SW_CFG<br>PERIO 800M Clock Gate Enable<br>0: Disable<br>1: Enable |
| 25             | R/W        | 0x1         | PERIO_600M_GATE_SW_CFG<br>PERIO 600M Clock Gate Enable                            |

| Offset: 0xE08 |            |             | Register Name: PERI0PLL_GATE_EN_REG:                                              |
|---------------|------------|-------------|-----------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                       |
|               |            |             | 0: Disable<br>1:Enable                                                            |
| 24            | R/W        | 0x1         | PERI0_480M_GATE_ALL_CFG<br>PERI0 480M Clock Gate Enable<br>0: Disable<br>1:Enable |
| 23            | R/W        | 0x1         | PERI0_480M_GATE_SW_CFG<br>PERI0 480M Clock Gate Enable<br>0: Disable<br>1:Enable  |
| 22            | R/W        | 0x1         | PERI0_160M_GATE_SW_CFG<br>PERI0 160M Clock Gate Enable<br>0: Disable<br>1:Enable  |
| 21            | R/W        | 0x1         | PERI0_300M_GATE_ALL_CFG<br>PERI0 300M Clock Gate Enable<br>0: Disable<br>1:Enable |
| 20            | R/W        | 0x1         | PERI0_300M_GATE_SW_CFG<br>PERI0 300M Clock Gate Enable<br>0: Disable<br>1:Enable  |
| 19            | R/W        | 0x1         | PERI0_150M_GATE_SW_CFG<br>PERI0 150M Clock Gate Enable<br>0: Disable<br>1:Enable  |
| 18            | R/W        | 0x1         | PERI0_400M_GATE_ALL_CFG<br>PERI0 400M Clock Gate Enable<br>0: Disable<br>1:Enable |
| 17            | R/W        | 0x1         | PERI0_400M_GATE_SW_CFG<br>PERI0 400M Clock Gate Enable<br>0: Disable<br>1:Enable  |
| 16            | R/W        | 0x1         | PERI0_200M_GATE_SW_CFG<br>PERI0 200M Clock Gate Enable<br>0: Disable<br>1:Enable  |
| 15:12         | /          | /           | /                                                                                 |
| 11            | R/W        | 0x1         | PERI0PLL2X_AUTO_GATE_EN<br>PERI0PLL2X Clock Auto Gate Enable                      |

| Offset: 0xE08 |            |             | Register Name: PERI0PLL_GATE_EN_REG:                                                         |
|---------------|------------|-------------|----------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                  |
|               |            |             | 0: Auto<br>1:No-Auto                                                                         |
| 10            | R/W        | 0x1         | PERI0_800M_AUTO_GATE_EN<br>PERI0 800M Clock Auto Gate Enable<br>0: Auto<br>1:No-Auto         |
| 9             | R/W        | 0x1         | PERI0_600M_AUTO_GATE_EN<br>PERI0 600M Clock Auto Gate Enable<br>0: Auto<br>1:No-Auto         |
| 8             | R/W        | 0x1         | PERI0_480M_AUTO_GATE_EN_ALL<br>PERI0 480M Clock Auto Gate Enable<br>0: Auto<br>1:No-Auto     |
| 7             | R/W        | 0x1         | PERI0_480M_AUTO_GATE_EN<br>PERI0 480M Clock Auto Gate Enable<br>0: Auto<br>1:No-Auto         |
| 6             | R/W        | 0x1         | PERI0_160M_AUTO_GATE_EN<br>PERI0 160M Clock Auto Gate Enable<br>0: Auto<br>1:No-Auto         |
| 5             | R/W        | 0x1         | PERI0_300M_AUTO_GATE_EN_ALL<br>PERI0 300M Clock Auto Gate Enable<br>0: Auto<br>1:No-Auto     |
| 4             | R/W        | 0x1         | PERI0_300M_AUTO_GATE_EN<br>PERI0 300M Clock Auto Gate Enable<br>0: Auto<br>1:No-Auto         |
| 3             | R/W        | 0x1         | PERI0_150M_AUTO_GATE_EN<br>PERI0 150M Clock Auto Gate Enable<br>0: Auto<br>1:No-Auto         |
| 2             | R/W        | 0x1         | PERI0_400M_AUTO_GATE_EN_ALL<br>PERI0 400M Clock Auto Gate Enable All<br>0: Auto<br>1:No-Auto |
| 1             | R/W        | 0x1         | PERI0_400M_AUTO_GATE_EN<br>PERI0 400M Clock Auto Gate Enable<br>0: Auto                      |

| Offset: 0x0E08 |            |             | Register Name: PERI0PLL_GATE_EN_REG:                                                 |
|----------------|------------|-------------|--------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                          |
|                |            |             | 1:No-Auto                                                                            |
| 0              | R/W        | 0x1         | PERI0_200M_AUTO_GATE_EN<br>PERI0 200M Clock Auto Gate Enable<br>0: Auto<br>1:No-Auto |

#### 2.5.6.136 0x0E0C CLK24M Gate Enable Register (Default Value: 0x0000\_0009)

| Offset: 0x0E0C |            |             | Register Name: CLK24M_GATE_EN_REG                                                |
|----------------|------------|-------------|----------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                      |
| 31:4           | /          | /           | /                                                                                |
| 3              | R/W        | 0x1         | RES_DCAP_24M_GATE_EN<br>RES_DCAP 24M Clock Gate Enable<br>0: Disable<br>1:Enable |
| 2:1            | /          | /           | /                                                                                |
| 0              | R/W        | 0x1         | USB_24M_GATE_EN<br>USB 24M Clock Gate Enable<br>0: Disable<br>1:Enable           |

#### 2.5.6.137 0x0E10 PERI1PLL Gate Enable Register (Default Value: 0x8EBF\_0EBF)

| Offset: 0x0E10 |            |             | Register Name: PERI1PLL_GATE_EN_REG:                                              |
|----------------|------------|-------------|-----------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                       |
| 31:28          | /          | /           | /                                                                                 |
| 27             | R/W        | 0x1         | PERI1_800M_GATE_SW_CFG<br>PERI1 800M Clock Gate Enable<br>0: Disable<br>1:Enable  |
| 26             | R/W        | 0x1         | PERI1_600M_GATE_ALL_CFG<br>PERI1 600M Clock Gate Enable<br>0: Disable<br>1:Enable |
| 25             | R/W        | 0x1         | PERI1_600M_GATE_SW_CFG<br>PERI1 600M Clock Gate Enable<br>0: Disable<br>1:Enable  |
| 24             | /          | /           | /                                                                                 |
| 23             | R/W        | 0x1         | PERI1_480M_GATE_SW_CFG                                                            |

| Offset: 0xE10 |            |             | Register Name: PERI1PLL_GATE_EN_REG:                                                     |
|---------------|------------|-------------|------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                              |
|               |            |             | PERI1 480M Clock Gate Enable<br>0: Disable<br>1:Enable                                   |
| 22            | /          | /           | /                                                                                        |
| 21            | R/W        | 0x1         | PERI1_300M_GATE_ALL_CFG<br>PERI1 300M Clock Gate Enable<br>0: Disable<br>1:Enable        |
| 20            | R/W        | 0x1         | PERI1_300M_GATE_SW_CFG<br>PERI1 300M Clock Gate Enable<br>0: Disable<br>1:Enable         |
| 19            | R/W        | 0x1         | PERI1_150M_GATE_SW_CFG<br>PERI1 150M Clock Gate Enable<br>0: Disable<br>1:Enable         |
| 18            | R/W        | 0x1         | PERI1_400M_GATE_ALL_CFG<br>PERI1 400M Clock Gate Enable<br>0: Disable<br>1:Enable        |
| 17            | R/W        | 0x1         | PERI1_400M_GATE_SW_CFG<br>PERI1 400M Clock Gate Enable<br>0: Disable<br>1:Enable         |
| 16            | R/W        | 0x1         | PERI1_200M_GATE_SW_CFG<br>PERI1 200M Clock Gate Enable<br>0: Disable<br>1:Enable         |
| 15:12         | /          | /           | /                                                                                        |
| 11            | R/W        | 0x1         | PERI1_800M_AUTO_GATE_EN<br>PERI1 800M Clock Auto Gate Enable<br>0: Auto<br>1:No-Auto     |
| 10            | R/W        | 0x1         | PERI1_600M_AUTO_GATE_EN_ALL<br>PERI1 600M Clock Auto Gate Enable<br>0: Auto<br>1:No-Auto |
| 9             | R/W        | 0x1         | PERI1_600M_AUTO_GATE_EN<br>PERI1 600M Clock Auto Gate Enable<br>0: Auto<br>1:No-Auto     |

| Offset: 0xE10 |            |             | Register Name: PERI1PLL_GATE_EN_REG:                                                         |
|---------------|------------|-------------|----------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                  |
| 8             | /          | /           | /                                                                                            |
| 7             | R/W        | 0x1         | PERI1_480M_AUTO_GATE_EN<br>PERI1 480M Clock Auto Gate Enable<br>0: Auto<br>1:No-Auto         |
| 6             | /          | /           | /                                                                                            |
| 5             | R/W        | 0x1         | PERI1_300M_AUTO_GATE_EN_ALL<br>PERI1 300M Clock Auto Gate Enable<br>0: Auto<br>1:No-Auto     |
| 4             | R/W        | 0x1         | PERI1_300M_AUTO_GATE_EN<br>PERI1 300M Clock Auto Gate Enable<br>0: Auto<br>1:No-Auto         |
| 3             | R/W        | 0x1         | PERI1_150M_AUTO_GATE_EN<br>PERI1 150M Clock Auto Gate Enable<br>0: Auto<br>1:No-Auto         |
| 2             | R/W        | 0x1         | PERI1_400M_AUTO_GATE_EN_ALL<br>PERI1 400M Clock Auto Gate Enable All<br>0: Auto<br>1:No-Auto |
| 1             | R/W        | 0x1         | PERI1_400M_AUTO_GATE_EN<br>PERI1 400M Clock Auto Gate Enable<br>0: Auto<br>1:No-Auto         |
| 0             | R/W        | 0x1         | PERI1_200M_AUTO_GATE_EN<br>PERI1 200M Clock Auto Gate Enable<br>0: Auto<br>1:No-Auto         |

#### 2.5.6.138 0xE14 VIDEOPLL Gate Enable Register (Default Value: 0x00BF\_00BF)

| Offset: 0xE14 |            |             | Register Name: VIDEOPLL_GATE_EN_REG                                                |
|---------------|------------|-------------|------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                        |
| 31:24         | /          | /           | /                                                                                  |
| 23            | R/W        | 0x1         | VIDEO3PLL3X_GATE_SW_CFG<br>VIDEO3PLL3X Clock Gate Enable<br>0: Disable<br>1:Enable |

| Offset: 0xE14 |            |             | Register Name: VIDEOPLL_GATE_EN_REG                                                    |
|---------------|------------|-------------|----------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                            |
| 22            | /          | /           | /                                                                                      |
| 21            | R/W        | 0x1         | VIDEO1PLL3X_GATE_SW_CFG<br>VIDEO1PLL3X Clock Gate Enable<br>0: Disable<br>1:Enable     |
| 20            | R/W        | 0x1         | VIDEO0PLL3X_GATE_SW_CFG<br>VIDEO0PLL3X Clock Gate Enable<br>0: Disable<br>1:Enable     |
| 19            | R/W        | 0x1         | VIDEO3PLL4X_GATE_SW_CFG<br>VIDEO3PLL4X Clock Gate Enable<br>0: Disable<br>1:Enable     |
| 18            | R/W        | 0x1         | VIDEO2PLL4X_GATE_SW_CFG<br>VIDEO2PLL4X Clock Gate Enable<br>0: Disable<br>1:Enable     |
| 17            | R/W        | 0x1         | VIDEO1PLL4X_GATE_SW_CFG<br>VIDEO1PLL4X Clock Gate Enable<br>0: Disable<br>1:Enable     |
| 16            | R/W        | 0x1         | VIDEO0PLL4X_GATE_SW_CFG<br>VIDEO0PLL4X Clock Gate Enable<br>0: Disable<br>1:Enable     |
| 15:8          | /          | /           | /                                                                                      |
| 7             | R/W        | 0x1         | VIDEO3PLL3X_AUTO_GATE_EN<br>VIDEO3PLL3X Clock Auto Gate Enable<br>0: Auto<br>1:No-Auto |
| 6             | /          | /           | /                                                                                      |
| 5             | R/W        | 0x1         | VIDEO1PLL3X_AUTO_GATE_EN<br>VIDEO1PLL3X Clock Auto Gate Enable<br>0: Auto<br>1:No-Auto |
| 4             | R/W        | 0x1         | VIDEO0PLL3X_AUTO_GATE_EN<br>VIDEO0PLL3X Clock Auto Gate Enable<br>0: Auto<br>1:No-Auto |
| 3             | R/W        | 0x1         | VIDEO3PLL4X_AUTO_GATE_EN<br>VIDEO3PLL4X Clock Auto Gate Enable                         |

| Offset: 0xE14 |            |             | Register Name: VIDEOPLL_GATE_EN_REG                                                    |
|---------------|------------|-------------|----------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                            |
|               |            |             | 0: Auto<br>1:No-Auto                                                                   |
| 2             | R/W        | 0x1         | VIDEO2PLL4X_AUTO_GATE_EN<br>VIDEO2PLL4X Clock Auto Gate Enable<br>0: Auto<br>1:No-Auto |
| 1             | R/W        | 0x1         | VIDEO1PLL4X_AUTO_GATE_EN<br>VIDEO1PLL4X Clock Auto Gate Enable<br>0: Auto<br>1:No-Auto |
| 0             | R/W        | 0x1         | VIDEO0PLL4X_AUTO_GATE_EN<br>VIDEO0PLL4X Clock Auto Gate Enable<br>0: Auto<br>1:No-Auto |

#### 2.5.6.139 0xE20 CM GPU Enable Configuration Register (Default Value: 0x0002\_0000)

| Offset: 0xE20 |            |             | Register Name: CM_GPU_CFG_REG                                       |
|---------------|------------|-------------|---------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                         |
| 31:18         | /          | /           | /                                                                   |
| 17:16         | R          | 0x2         | CM_GPU_STATUS<br>CM GPU Status<br>01: Power OFF<br>10: Power ON     |
| 15:1          | /          | /           | /                                                                   |
| 0             | R/W        | 0x0         | CM_GPU_MODULE_MODE<br>CM GPU module mode<br>0: Disable<br>1: Enable |

#### 2.5.6.140 0xE24 CM VE Enable Configuration Register (Default Value: 0x0002\_0000)

| Offset: 0xE24 |     |             | Register Name: CM_VE_CFG_REG                                  |
|---------------|-----|-------------|---------------------------------------------------------------|
| Bit           | R/W | Default/Hex | Description                                                   |
| 31:18         | /   | /           | /                                                             |
| 17:16         | R   | 0x2         | CM_VE_STATUS<br>CM VE Status<br>01: Power OFF<br>10: Power ON |
| 15:1          | /   | /           | /                                                             |

| Offset: 0x0E24 |     |             | Register Name: CM_VE_CFG_REG                                      |
|----------------|-----|-------------|-------------------------------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                                       |
| 0              | R/W | 0x0         | CM_VE_MODULE_MODE<br>CM VE module mode<br>0: Disable<br>1: Enable |

#### 2.5.6.141 0xE28 CM DE Enable Configuration Register (Default Value:0x0002\_0000)

| Offset: 0x0E28 |     |             | Register Name: CM_DE_CFG_REG                                      |
|----------------|-----|-------------|-------------------------------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                                       |
| 31:18          | /   | /           | /                                                                 |
| 17:16          | R   | 0x2         | CM_DE_STATUS<br>CM DE Status<br>01: Power OFF<br>10: Power ON     |
| 15:1           | /   | /           | /                                                                 |
| 0              | R/W | 0x0         | CM_DE_MODULE_MODE<br>CM DE module mode<br>0: Disable<br>1: Enable |

#### 2.5.6.142 0xE2C CM VI Enable Configuration Register (Default Value:0x0002\_0000)

| Offset: 0x0E2C |     |             | Register Name: CM_VI_CFG_REG                                      |
|----------------|-----|-------------|-------------------------------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                                       |
| 31:18          | /   | /           | /                                                                 |
| 17:16          | R   | 0x2         | CM_VI_STATUS<br>CM VI Status<br>01: Power OFF<br>10: Power ON     |
| 15:1           | /   | /           | /                                                                 |
| 0              | R/W | 0x0         | CM_VI_MODULE_MODE<br>CM VI module mode<br>0: Disable<br>1: Enable |

#### 2.5.6.143 0xE30 CM VO0 Enable Configuration Register (Default Value:0x0002\_0000)

| Offset: 0x0E30 |     |             | Register Name: CM_VO0_CFG_REG |
|----------------|-----|-------------|-------------------------------|
| Bit            | R/W | Default/Hex | Description                   |

| Offset: 0x0E30 |     |             | Register Name: CM_VO0_CFG_REG                                       |
|----------------|-----|-------------|---------------------------------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                                         |
| 31:18          | /   | /           | /                                                                   |
| 17:16          | R   | 0x2         | CM_VO0_STATUS<br>CM VO0 Status<br>01: Power OFF<br>10: Power ON     |
| 15:1           | /   | /           | /                                                                   |
| 0              | R/W | 0x0         | CM_VO0_MODULE_MODE<br>CM VO0 module mode<br>0: Disable<br>1: Enable |

#### 2.5.6.144 0xE38 CM NFC Enable Configuration Register (Default Value:0x0002\_0000)

| Offset: 0x0E38 |     |             | Register Name: CM_NFC_CFG_REG                                       |
|----------------|-----|-------------|---------------------------------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                                         |
| 31:18          | /   | /           | /                                                                   |
| 17:16          | R   | 0x2         | CM_NFC_STATUS<br>CM NFC Status<br>01: Power OFF<br>10: Power ON     |
| 15:1           | /   | /           | /                                                                   |
| 0              | R/W | 0x0         | CM_NFC_MODULE_MODE<br>CM NFC module mode<br>0: Disable<br>1: Enable |

#### 2.5.6.145 0xE3C CM PCIE Enable Configuration Register (Default Value:0x0002\_0000)

| Offset: 0x0E3C |     |             | Register Name: CM_PCIE_CFG_REG                                        |
|----------------|-----|-------------|-----------------------------------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                                           |
| 31:18          | /   | /           | /                                                                     |
| 17:16          | R   | 0x2         | CM_PCIE_STATUS<br>CM PCIE Status<br>01: Power OFF<br>10: Power ON     |
| 15:1           | /   | /           | /                                                                     |
| 0              | R/W | 0x0         | CM_PCIE_MODULE_MODE<br>CM PCIE module mode<br>0: Disable<br>1: Enable |

**2.5.6.146 0x0F00 CCU Security Switch Register (Default Value: 0x0000\_0000)**

| Offset: 0x0F00 |            |             | Register Name: CCU_SEC_SWITCH_REG                                        |
|----------------|------------|-------------|--------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                              |
| 31:3           | /          | /           | /                                                                        |
| 2              | R/W        | 0x0         | MBUS_SEC<br>MBUS clock register security<br>0: Secure<br>1: Non-secure   |
| 1              | R/W        | 0x0         | BUS_SEC<br>Bus relevant registers security<br>0: Secure<br>1: Non-secure |
| 0              | R/W        | 0x0         | PLL_SEC<br>PLL relevant registers security<br>0: Secure<br>1: Non-secure |

**2.5.6.147 0x0F08 SYSDAP REQ Control Register (Default Value: 0x0000\_0001)**

| Offset: 0x0F08 |            |             | Register Name: SYSDAP_REQ_CTRL_REG                                                                                                                       |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                              |
| 31:1           | /          | /           | /                                                                                                                                                        |
| 0              | R/W        | 0x1         | SYSDAP_REQ_ENABLE<br>0: Disable<br>1: Enable<br>By configuring this bit, SYSDAP REQ signal could be set to control the clock and reset of CE and DAPSYS. |

**2.5.6.148 0x0F30 CCU FANOUT CLOCK GATE Register (Default Value:0x0000\_0000)**

| Offset: 0x0F30 |            |             | Register Name: CCU_FAN_GATE_REG                                     |
|----------------|------------|-------------|---------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                         |
| 31:5           | /          | /           | /                                                                   |
| 4              | R/W        | 0x0         | CLK50M_EN<br>Gating for CLK50M<br>0: Clock is OFF<br>1: Clock is ON |
| 3              | R/W        | 0x0         | CLK25M_EN<br>Gating for CLK25M<br>0: Clock is OFF<br>1: Clock is ON |

| Offset: 0x0F30 |            |             | Register Name: CCU_FAN_GATE_REG                                     |
|----------------|------------|-------------|---------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                         |
| 2              | R/W        | 0x0         | CLK16M_EN<br>Gating for CLK16M<br>0: Clock is OFF<br>1: Clock is ON |
| 1              | R/W        | 0x0         | CLK12M_EN<br>Gating for CLK12M<br>0: Clock is OFF<br>1: Clock is ON |
| 0              | R/W        | 0x0         | CLK24M_EN<br>Gating for CLK24M<br>0: Clock is OFF<br>1: Clock is ON |

#### 2.5.6.149 0x0F34 CLK27M FANOUT Register (Default Value:0x0000\_0000)

| Offset: 0x0F34 |            |             | Register Name: CLK27M_FAN_REG                                                                                         |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                           |
| 31             | R/W        | 0x0         | CLK27M_EN<br>Gating for CLK27M<br>0: Clock is OFF<br>1: Clock is ON<br>SCLK=Clock Source/M/N                          |
| 30:26          | /          | /           | /                                                                                                                     |
| 25:24          | R/W        | 0x0         | CLK27M_SCR_SEL<br>Clock Source Select<br>000: VIDEO0PLL4X<br>001: VIDEO1PLL4X<br>010: VIDEO2PLL4X<br>011: VIDEO3PLL4X |
| 23:13          | /          | /           | /                                                                                                                     |
| 12:8           | R/W        | 0x0         | CLK27M_DIV1<br>Factor N<br>N=FACTOR_N +1<br>FACTOR_M is from 0 to 31.                                                 |
| 7:5            | /          | /           | /                                                                                                                     |
| 4:0            | R/W        | 0x0         | CLK27M_DIV0<br>Factor M<br>M=FACTOR_M +1<br>FACTOR_M is from 0 to 31.                                                 |

## 2.5.6.150 0x0F38 CLK FANOUT Register (Default Value:0x0000\_0000)

| Offset: 0x0F38 |            |             | Register Name: CLK_FAN_REG                                                                 |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                |
| 31             | R/W        | 0x0         | PCLK_DIV_EN<br>Gating for PCLK<br>0: Clock is OFF<br>1: Clock is ON<br>PCLK = APB0_CLK/M/N |
| 30:10          | /          | /           | /                                                                                          |
| 9:5            | R/W        | 0x0         | PCLK_DIV1<br>Factor N<br>N= FACTOR_N +1<br>FACTOR_N is from 0 to 31.                       |
| 4:0            | R/W        | 0x0         | PCLK_DIV<br>Factor M<br>M= FACTOR_M +1<br>FACTOR_M is from 0 to 31.                        |

## 2.5.6.151 0x0F3C CCU FANOUT Register (Default Value:0x0000\_0007)

| Offset: 0x0F3C |            |             | Register Name: CCU_FAN_REG                                                    |
|----------------|------------|-------------|-------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                   |
| 31:27          | /          | /           | /                                                                             |
| 26:24          | R/W        | 0x0         | Reserved                                                                      |
| 23             | R/W        | 0x0         | CLK_FANOUT2_EN<br>Gating for CLK_FANOUT2<br>0: Clock is OFF<br>1: Clock is ON |
| 22             | R/W        | 0x0         | CLK_FANOUT1_EN<br>Gating for CLK_FANOUT1<br>0: Clock is OFF<br>1: Clock is ON |
| 21             | R/W        | 0x0         | CLK_FANOUT0_EN<br>Gating for CLK_FANOUT0<br>0: Clock is OFF<br>1: Clock is ON |
| 20:18          | /          | /           | /                                                                             |
| 17:9           | R/W        | 0x0         | Reserved                                                                      |
| 8:6            | R/W        | 0x0         | CLK_FANOUT2_SEL<br>Clock Fanout2 Select<br>000: CLK32K_FANOUT (From SYSRTC)   |

| Offset: 0x0F3C |            |             | Register Name: CCU_FAN_REG                                                                                                                                                                                                                                                                                                                              |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                             |
|                |            |             | 001: CLK12M (From DCXO/2)<br>010: CLK16M (From PERIO_160M/10)<br>011: CLK24M (From DCXO)<br>100: CLK25M (From PERIO_150M/6)<br>101: CLK27M<br>110: PCLK<br>111: CLK50M (From PERIO_150M/3)<br>CLK_FANOUT2 can be selected to output from the above seven sources.                                                                                       |
| 5:3            | R/W        | 0x0         | <b>CLK_FANOUT1_SEL</b><br>Clock Fanout1 Select<br>000: CLK32K_FANOUT (From SYSRTC)<br>001: CLK12M (From DCXO/2)<br>010: CLK16M (From PERIO_160M/10)<br>011: CLK24M (From DCXO)<br>100: CLK25M (From PERIO_150M/6)<br>101: CLK27M<br>110: PCLK<br>111: CLK50M (From PERIO_150M/3)<br>CLK_FANOUT1 can be selected to output from the above seven sources. |
| 2:0            | R/W        | 0x7         | <b>CLK_FANOUT0_SEL</b><br>Clock Fanout0 Select<br>000: CLK32K_FANOUT (From SYSRTC)<br>001: CLK12M (From DCXO/2)<br>010: CLK16M (From PERIO_160M/10)<br>011: CLK24M (From DCXO)<br>100: CLK25M (From PERIO_150M/6)<br>101: CLK27M<br>110: PCLK<br>111: CLK50M (From PERIO_150M/3)<br>CLK_FANOUT0 can be selected to output from the above seven sources. |

#### 2.5.6.152 0x0F40 PLL Configuration0 Register (Default Value: 0x0000\_0000)

| Offset: 0x0F40 |            |             | Register Name: PLL_CFG0_REG                         |
|----------------|------------|-------------|-----------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                         |
| 31:0           | R/W        | 0x0         | <b>PLL_CONFIG0</b><br>PLL Control Reserved Register |

## 2.5.6.153 0x0F44 PLL Configuration1 Register (Default Value: 0x0000\_0000)

| Offset: 0x0F44 |            |             | Register Name: PLL_CFG1_REG                  |
|----------------|------------|-------------|----------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                  |
| 31:0           | R/W        | 0x0         | PLL_CONFIG1<br>PLL Control Reserved Register |

## 2.5.6.154 0x0F48 PLL Configuration2 Register (Default Value: 0x0000\_0000)

| Offset: 0x0F48 |            |             | Register Name: PLL_CFG2_REG                  |
|----------------|------------|-------------|----------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                  |
| 31:0           | R/W        | 0x0         | PLL_CONFIG2<br>PLL Control Reserved Register |

## 2.6 DMA Controller (DMAC)

### 2.6.1 Overview

The direct memory access (DMA) is a method of transferring data between peripherals and memories (including the SRAM and DRAM) without using the CPU. It is an efficient way to offload data transfer duties from the CPU. Without DMA, the CPU has to control all the data transfers. While with DMA, the DMAC directly transfers data between a peripheral and a memory, between peripherals, or between memories.

The DMAC has the following features:

- Up to 16-ch DMA in CPUX domain and 16-ch DMA in CPUS domain
- Provides 53 peripheral DMA requests for data reading and 53 peripheral DMA requests for data writing
- Transferring data with linked list
- Flexible data width: 8 bits, 16 bits, or, 32 bits
- Programmable DMA burst length
- DRQ response includes waiting mode and handshake mode
- Supports non-aligned transform for memory devices
- DMA channels that support the following:
  - Pausing DMA
  - BMODE and I/O speed mode
  - DMA timeout



#### NOTE

The following description focuses on the DMA of the CPUX domain.

## 2.6.2 Block Diagram

The following figure shows a block diagram of DMAC.

**Figure 2-10 DMAC Block Diagram**



DMAC contains the following sub-blocks:

**Table 2-11 DMAC Sub-blocks**

| Sub-block     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DMA_ARBITER   | Arbitrates the DMA read/write requests from all channels, and converts the requests to the read/write requests of ports.                                                                                                                                                                                                                                                                                                                                                                                                                             |
| DMA_CHANNELS  | DMA transfer engine. Each channel is independent. When the DMA requests from multiple peripherals are valid simultaneously, the channel with the highest priority starts data transfer first. The system uses the polling mechanism to decide the priorities of DMA channels. When DMA_ARBITER is idle, channel 0 has the highest priority, whereas channel 15 has the lowest priority. When DMA_ARBITER is busy processing the request from channel n, channel (n+1) has the highest priority. For n = 15, the channel (n + 1) should be channel 0. |
| DRQs          | DMA requests. Peripherals use the DMA request signals to request a data transfer.                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| DMA_MPORT     | Receives the read/write requests from DMA_ARBITER, and converts the requests to the corresponding MBUS access requests. It is mainly used for accessing the DRAM.                                                                                                                                                                                                                                                                                                                                                                                    |
| DMA_HPORT     | The port for accessing the AHB Master. It is mainly used for accessing the SRAM and IO devices.                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| DMA_FIFO CTRL | Internal FIFO cell control module.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

| Sub-block         | Description                                                                        |
|-------------------|------------------------------------------------------------------------------------|
| DMA_REG Interface | DMA_REG is the common register module that is mainly used to resolve AHB commands. |
| DMA_CLKGATE       | The control module for hardware auto clock gating.                                 |

The DMAC integrates 16 independent DMA channels and each channel has an independent FIFO controller. When the DMA channel starts, the DMAC gets a DMA descriptor from the DMA\_DESC\_ADDR\_REG and uses it as the configuration information for the data transfer of the current DMA package. Then the DMAC can transfer data between the specified devices. After transferring a DMA package, the DMAC judges if the current channel transfer is finished via the linked address in the descriptor. If the linked address shows all the packages are transferred, the DMAC will end the chain transmission and close the channel.

### 2.6.3 Functional Description

#### 2.6.3.1 Clock

The DMAC is on AHB or MBUS. The clocks of AHB and MBUS influence the transfer efficiency of the DMAC.

#### 2.6.3.2 Typical Application

The following figure shows a typical application of the DMAC.

Figure 2-11 DMAC Typical Application Diagram



### 2.6.3.3 DRQ Port of Peripherals

The following tables show the source DRQ types and destination DRQ types of different ports.

Table 2-12 DMA DRQ Type

| Source DRQ Type |          | Destination DRQ Type |          |
|-----------------|----------|----------------------|----------|
| port0           | SRAM     | port0                | SRAM     |
| port1           | DRAM     | port1                | DRAM     |
| port2           |          | port2                |          |
| port3           |          | port3                |          |
| port4           |          | port4                |          |
| port5           |          | port5                |          |
| port6           |          | port6                |          |
| port7           |          | port7                |          |
| port8           |          | port8                |          |
| port9           |          | port9                |          |
| port10          | NDFC     | port10               | NDFC     |
| port11          |          | port11               |          |
| port12          | GPADC    | Port12               |          |
| port13          |          | port13               | CIR_TX   |
| port14          | UART0_RX | port14               | UART0_TX |
| port15          | UART1_RX | port15               | UART1_TX |
| port16          | UART2_RX | port16               | UART2_TX |
| port17          | UART3_RX | port17               | UART3_TX |
| port18          | UART4_RX | port18               | UART4_TX |
| port19          | UART5_RX | port19               | UART5_TX |
| port20          | UART6_RX | Port20               | UART6_TX |
| port21          | UART7_RX | port21               | UART7_TX |
| port22          | SPI0_RX  | port22               | SPI0_TX  |
| port23          | SPI1_RX  | port23               | SPI1_TX  |
| port24          | SPI2_RX  | port24               | SPI2_TX  |
| port25          |          | port25               |          |
| port26          |          | port26               |          |
| port27          |          | port27               |          |
| port28          |          | port28               |          |
| port29          |          | port29               |          |
| Port30          | USB0_EP1 | Port30               | USB0_EP1 |
| Port31          | USB0_EP2 | Port31               | USB0_EP2 |
| Port32          | USB0_EP3 | Port32               | USB0_EP3 |
| Port33          | USB0_EP4 | Port33               | USB0_EP4 |
| Port34          | USB0_EP5 | Port34               | USB0_EP5 |
| Port35          |          | Port35               |          |
| Port36          |          | Port36               |          |

| Source DRQ Type |         | Destination DRQ Type |         |
|-----------------|---------|----------------------|---------|
| Port37          |         | Port37               |         |
| Port38          |         | Port38               |         |
| Port39          |         | Port39               |         |
| Port40          |         | Port40               |         |
| Port41          |         | Port41               |         |
| Port42          |         | Port42               | LEDC    |
| Port43          | TWI0    | Port43               | TWI0    |
| Port44          | TWI1    | Port44               | TWI1    |
| Port45          | TWI2    | Port45               | TWI2    |
| Port46          | TWI3    | Port46               | TWI3    |
| Port47          | TWI4    | Port47               | TWI4    |
| Port48          | TWI5    | Port48               | TWI5    |
| Port49          | S_TWI0  | Port49               | S_TWI0  |
| Port50          | S_TWI1  | Port50               | S_TWI1  |
| Port51          | S_UART0 | Port51               | S_UART0 |
| Port52          | S_UART1 | Port52               | S_UART1 |
| Port53          | S_SPI0  | Port53               | S_SPI0  |

Table 2-13 DMA DRQ Type of MCU\_DMAC

| Source DRQ Type |             | Destination DRQ Type |             |
|-----------------|-------------|----------------------|-------------|
| port0           | SRAM        | port0                | SRAM        |
| port1           | DRAM        | port1                | DRAM        |
| port2           | OWA         | port2                | OWA         |
| port3           | I2S0_RX     | port3                | I2S0_TX     |
| port4           | I2S1_RX     | port4                | I2S1_TX     |
| port5           | I2S2_RX     | port5                | I2S2_TX     |
| port6           | I2S3_RX     | port6                | I2S3_TX     |
| port7           | AUDIO_CODEC | port7                | AUDIO_CODEC |
| port8           | DMIC        | port8                |             |
| port9           | S_TWI0      | port9                | S_TWI0      |
| port10          | S_TWI1      | port10               | S_TWI1      |
| port11          | S_UART0     | port11               | S_UART0     |
| port12          | S_UART1     | port12               | S_UART1     |
| Port13          | S_SPI0      | Port13               | S_SPI0      |
| Port14          | S_TWI2      | Port14               | S_TWI2      |

#### 2.6.3.4 DMA Descriptor

The DMAC descriptor is the configuration information of DMA transfer that decides the DMA working mode. Each descriptor includes 6 words: Configuration, Source Address, Destination Address, Byte Counter, Parameter, and Link. The following figure shows the structure of the DMA descriptor.

Figure 2-12 DMA Descriptor



- **Configuration:** Configure the following information.
  - DRQ type: DRQ type of the source and destination devices.
  - Address counting mode: For both the source and destination devices, there are two address counting modes: the IO mode and linear mode. The IO mode is for IO devices whose address is fixed during the data transfer and the linear mode is for the memory whose address is increasing during the data transfer.
  - Transferred block length: How many times can non-memory peripherals transfer in a valid DRQ. The block length supports 1 time, 4 times, 8 times, and 16 times.
  - Transferred data width: The data width of operating the non-memory peripherals. The data width supports 8 bits, 16 bits, and 32 bits.



#### NOTE

The configuration supports BMODE mode. The BMODE is used in the following scenario: the source is an IO device, and the destination is a memory device. Setting the BMODE mode can limit the amount of block data transferred in DMA block transmission to the amount of data transferred when the DRQ threshold of the source IO device is 1.

- **Source Address:** Configure the address of the source device.
- **Destination Address:** Configure the address of the destination device.

DMA reads data from the source address and then writes data to the destination address.

Both the DMA source and destination addresses have 34 bits. In the descriptor, because there are only 32 bits in the Source/Destination Address field, another 2 bits are stored in the Parameter field.

The following table shows the details of the related fields in the descriptor.

**Table 2-14 Source/Destination Address Distribution**

| Descriptor Group    | Bit   | Description                                                                                                                                                                                                                                                                  |
|---------------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Source Address      | 31:0  | DMA transfers the lower 32 bits of the 34-bit source address                                                                                                                                                                                                                 |
| Destination Address | 31:0  | DMA transfers the lower 32 bits of the 34-bit destination address                                                                                                                                                                                                            |
| Parameter           | 31    | TIMEOUT Enable<br>TIMEOUT only can be enabled in BMODE and IOspeed should be disabled when using this function.                                                                                                                                                              |
|                     | 30:29 | TIMEOUT Configuration<br>00: Not use sub-functions<br>01: Generate an interrupt and suspend the transmission after timeout.<br>10: Generate an interrupt and end the transmission after timeout.<br>11: Generate an interrupt and skip to the next descriptor after timeout. |
|                     | 28:20 | TIMEOUT Configuration<br>Timer time of channels.                                                                                                                                                                                                                             |
|                     | 19:18 | DMA transfers the higher 2 bits of the 34-bit destination address                                                                                                                                                                                                            |
|                     | 17:16 | DMA transfers the high 2 bits of the 34-bit source address                                                                                                                                                                                                                   |
|                     | 15:9  | Reserved                                                                                                                                                                                                                                                                     |
|                     | 8     | I/O Speed Mode Enable<br>If this bit is enabled, DMA will transmit the data of the I/O device from the source device or the destination device, or both of them at a faster speed.<br><b>Note: IOspeed and BMODE cannot be enabled at the same time.</b>                     |
|                     | 7:0   | Wait Clock Cycles<br>Set the waiting time in DRQ mode                                                                                                                                                                                                                        |
| Link                | 31:2  | The address of the next group descriptor, the lower 30 bits of the word address                                                                                                                                                                                              |
|                     | 1:0   | The address of the next group descriptor, the higher 2 bits of the word address                                                                                                                                                                                              |

From the above table, you can get:

Real DMA source address (in byte mode) = {Parameter [17:16], Source Address [31:0]};

Real DMA destination address (in byte mode) = {Parameter [19:18], Destination Address [31:0]};

Real link address (in byte mode) = {Link [1:0], Link [31:2], 2'b00}.

- **Byte counter:** Configure the data amount of a package. The maximum value is ( $2^{25}-1$ ) bytes. If the data amount of the package reaches the maximum value, even if DRQ is valid, the DMA will stop the current transfer.
- **Parameter:** Configure the interval between the data block. The parameter is valid for non-memory peripherals. When DMA detects that the DRQ is high, the DMA transfers the data block and ignores the status changes of the DRQ until the data transfer finishes. After that, the DMA waits for certain clock cycles (WAIT\_CYC) and executes the next DRQ detection. In addition, the Parameter is responsible for enabling and configuring TIMEOUT. In the case that the source device is an I/O device and the destination device is a memory device, the waiting time of a DRQ signal triggered by the source device can be set when TIMEOUT is enabled. When time is out, an interrupt signal of TIMEOUT will be generated by DMA. There are three sub-functions of TIMEOUT to be enabled (TIMEOUT will only generate interrupts if they are disabled): suspend the transmission of the current channel after an interrupt is generated; end the transmission of the current channel after an interrupt is generated; skip to the next descriptor for transmission after an interrupt is generated. (TIMEOUT only can be enabled in BMODE.)

The Parameter also configures whether the IOspeed is enabled or not. If IOspeed is enabled, DMA will transmit the data of the I/O device from the source device or the destination device, or both of them at a faster speed. The larger block indicates a faster speed. However, when the block is 1, the speed won't change a lot even if the IO speed is enabled.

- **Link:** If the value of the link is 0xFFFFF800, the current package is at the end of the linked list. The DMAC will stop the data transfer after transferring the package; otherwise, the value of the link is considered as the descriptor address of the next package.

Figure 2-13 DMA Chain Transfer



### 2.6.3.5 Interrupts

There are four kinds of DMA interrupts: the half package interrupt, package end interrupt, and queue end interrupt.

- Half package interrupt

When enabled, the DMAC sends out a half package interrupt after transferring half of a package.

- Package end interrupt

When enabled, the DMAC sends out a package end interrupt after transferring a complete package.

- Queue end interrupt

When enabled, the DMAC sends out a queue end interrupt after transferring a complete queue.

- Timeout interrupt

When TIMEOUT is enabled, DMA will generate a timeout interrupt after timeout.

Notice that when CPU does not respond to the interrupts timely, or two DMA interrupts are generated very closely, the later interrupt may override the former one. That is, from the perspective of the CPU, the DMAC has only a system interrupt source.

### 2.6.3.6 Clock Gating

The DMA\_CLK\_GATE module is a hardware module for controlling the clock gating automatically. It provides clock sources for sub-modules in DMAC and the module local circuits.

The DMA\_CLK\_GATE module consists of two parts: the channel clock gate and the common clock gate.

**Channel clock gate:** Controls the DMA clock of the DMA channels. When the system accesses the register of the current DMA channel and the DMA channel is enabled, the channel clock gate automatically opens the DMA clock. With a 16-HCLK-cycle delay after the system finishes accessing the register or the DMA data transfer is completed, the channel clock gate automatically closes the DMA clock. Also, the clock for the related circuits, such as for the channel control and FIFO control modules, will be closed.

**Common clock gate:** Controls the clocks of the DMA common circuits. The common circuits include the common circuit of the FIFO control module, MPORT module, and MBUS. When all the DMA channels are disabled, the common clock gate automatically closes the clocks for the above circuits.

The DMA clock gating can support all the functions stated above or not by software.

### 2.6.3.7 Transfer Mode

The peripherals initiate data transfer by transmitting DMA request signals to the DMAC. After receiving the request signal, the DMAC converts it to the internal DRQ signal and controls the DMA data transfer.

The DMAC supports two data transfer modes: the waiting mode and handshake mode.

#### The principle of waiting mode

- When the DMAC detects a valid external request signal, the DMAC starts to operate the peripheral device. The internal DRQ always holds high before the transferred data amount reaches the transferred block length.
- When the transferred data amount reaches the transferred block length, the internal DRQ pulls low automatically.
- The internal DRQ holds low for certain clock cycles (WAIT\_CYC), and then the DMAC restarts to detect the external requests. If the external request signal is valid, then the next transfer starts.

#### The principle of handshake mode

- When the DMAC detects a valid external request signal, the DMAC starts to operate the peripheral device. The internal DRQ always holds high before the transferred data amount reaches the transferred block length.
- When the transferred data amount reaches the transferred block length, the internal DRQ will be pulled down automatically. For the last data transfer of the block, the DMAC sends a DMA Last signal with the DMA commands to the peripheral device. The DMA Last signal will be packed as part of the DMA commands and transmitted on the bus. It is used to inform the peripheral device that it is the end of the data transfer for the current DRQ.
- When the peripheral device receives the DMA Last signal, it can judge that the data transfer for the current DRQ is finished. To continue the data transfer, it sends a DMA Active signal to the DMAC.



One DMA Active signal will be converted to one DRQ signal in the DMA module. To generate multiple DRQs, the peripheral device needs to send out multiple DMA Active signals via the bus protocol.

- When the DMAC received the DMA Active signal, it sends back a DMA ACK signal to the peripheral device.
- When the peripheral device receives the DMA ACK signal, it waits for all the operations on the local device completed, and both the FIFO and DRQ status refreshed. Then it invalidates the DMA Active signal.

- When the DMAC detects the falling edge of the DMA Active signal, it invalidates the corresponding DMA ACK signal, and restarts to detect the external request signals. If a valid request signal is detected, the next data transfer starts.

The following figure shows the workflow of the handshake mode.

**Figure 2-14 Workflow of the DMAC Handshake Mode**



#### 2.6.3.8 Address Auto-Alignment

For the non-IO devices whose start address is not 32-byte-aligned, the DMAC will adjust the address to 32-byte-aligned through the burst transfer within 32 bytes. Adjusting address to 32-byte-aligned improves the DRAM access efficiency.

The following example shows how the DMAC adjusts the address: when the peripheral device of a DMA channel is a non-IO device whose start address is 0x86 (not 32-byte-aligned), the DMAC firstly uses a 26-byte burst transfer to align the address to 0xA0 (32-byte-aligned), and then transfers data by 64-byte burst (the maximum transfer amount that MBUS allows).

The IO devices do not support address alignment, so the bit width of IO devices must match the address offset; otherwise, the DMAC will ignore the inconsistency and directly transmit data of the corresponding bit width to the address.

The address of the DMA descriptor does not support the address auto-alignment. Make sure the address is word-aligned; otherwise the DMAC cannot identify the descriptor.

### 2.6.3.9 DMAC Clock Control

- The DMAC clock is synchronous with the AHB clock. Make sure that the DMAC gating bit of AHB clock is enabled before accessing the DMAC register.
- The reset input signal of the DMAC is asynchronous with AHB and is low valid by default. Make sure that the reset signal of the DMAC is de-asserted before accessing the DMA register.
- To avoid the indefinite state within registers, de-assert the reset signal first, and then open the gating bit of AHB.
- The DMAC supports Clock Auto Gating function to reduce power consumption, the system will automatically disable the DMAC clock in the DMAC idle state. Clock Auto Gating is enabled by default.

## 2.6.4 Programming Guidelines

### 2.6.4.1 Using DMAC Transfer Process

The DMAC transfer process is as follows.

- Step 1** Configure [DMAC\\_IRQ\\_CPU\\_EN\\_REG](#) register and [DMAC\\_IRQ MCU\\_EN\\_REG](#) register to select whether the channel interrupt signal is transferred to CPU field or MCU field. If both of the two registers are not configured, the IRQ will be transferred to both CPU field and MCU field by default.
- Step 2** Request DMA channel, and check if the DMA channel is idle by checking if it is enabled. A disabled channel indicates it is idle, while an enabled channel indicates it is busy.
- Step 3** Write the descriptor with 6 words into the memory. The descriptor must be word-aligned. For more details, refer to section 2.6.3.4 DMA Descriptor.
- Step 4** Write the start address of the descriptor to [DMAC\\_DESC\\_ADDR\\_REG](#).
- Step 5** Enable the DMA channel, and write the corresponding channel to [DMAC\\_EN\\_REG](#).
- Step 6** The DMA obtains the descriptor information.
- Step 7** Start to transmit a package. When half of the package is completed, the DMA sends a Half Package Transfer Interrupt; when a total package is completed, the DMA sends a Package End Transfer Interrupt. This interrupt status can be read by [DMAC\\_IRQ\\_PEND\\_REG0](#).
- Step 8** Set [DMAC\\_PAU\\_REG](#) to pause or resume the data transfer.
- Step 9** After completing a total package transfer, the DMA decides to start the next package transfer or end the transfer by the link of the descriptor. If the link is 0xFFFFF800, the transfer ends; otherwise, the next package starts to transmit. When the transfer ends, the DMA sends a Queue End Transfer Interrupt.

Step 10 Disable the DMA channel.

Figure 2-15 DMAC Transfer Process



#### 2.6.4.2 Processing DMAC Interrupt

Follow the steps below to process the DMAC interrupt:

**Step 1** Enable interrupt: write the corresponding interrupt enable bit of [DMAC\\_IRQ\\_EN\\_REG0](#).

The system generates an interrupt when the corresponding condition is satisfied.

**Step 2** After entering the interrupt process, write to clear the interrupt pending and execute the process of waiting for the interrupt.

**Step 3** Resume the interrupt and continue to execute the interrupted process.

#### 2.6.4.3 Configuring DMAC

To configure the DMAC, follow the guidelines below:

- Make sure the transfer bit width of IO devices is consistent with the offset of the start address.
- The MBUS protocol does not support the read operation of non-integer words. For the devices whose bit width is not word-aligned, after receiving the read command, they should resolve the read command according to their FIFO bit width instead of the command bit width, and ignore the redundant data caused by the inconsistency of the bit width.
- When the DMA transfer is paused, this is equivalent to invalid DRQ. Because there is a certain time delay between DMA transfer commands, the DMAC will not stop data transfer until the DMAC finishes processing the current command and the commands in Arbiter (at most 128 bytes' data).
- IOspeed and BMODE cannot be enabled at the same time.
- As DMA will transmit interrupts to [DMAC\\_IRQ\\_CPU\\_EN\\_REG](#) and [DMAC\\_IRQ MCU\\_EN\\_REG](#) by default simultaneously, it should be configured which one receives interrupts before transmission, and the other one ought to be disabled.
- Timeout Programming Instruction
  - Similar to the register configuration of other channels, configure by descriptors and read through registers.
  - Enable BMODE before using TIMEOUT functions.
  - Before enabling TIMEOUT functions, if the source device configures the descriptor Config [7:6] as 0, set the [DMAC\\_MODE\\_REG](#) [4] as 1, and then start the DMA transfer.
  - After enabling the pause function of TIMEOUT, resume the data transfer by configuring the [DMAC\\_PAU\\_REG](#).
  - After enabling the stop function of TIMEOUT, when TIMEOUT generates an interrupt, DMA will not generate the interrupt end signal of package and write-back. To restart the channel, configure the descriptors again.

- After enabling the jump function of TIMEOUT, when TIMEOUT generates an interrupt, DMA will not generate the interrupt end signal of package and write-back but skip to the next descriptor. Whether to start the TIMEOUT functions is decided by the descriptor being executed at that time. If there is no descriptor, transmission ends.
- The entered count number= the time to be counted \* clock frequency (DMA clock frequency)/4096
- Take an example of 200MHz clock frequency for DMA. If the step size of timer is 20.48 us, and the maximum count is 511, the longest counting time will be the maximum count\*step size=10.46 ms, and the shortest counting time will be 1\*step size=20.48 us.

DMAC application example:

```
writel(0x00000000, mem_address + 0x00); //Set configurations. The mem_address must be word-aligned.  
writel (0x00001000, mem_address + 0x04); // Set the start address for the source device.  
writel (0x20000000, mem_address + 0x08); //Set the start address for the destination device.  
writel (0x00000020, mem_address + 0x0C); // Set the data package size.  
writel (0x00000000, mem_address + 0x10); //Set the parameters.  
writel (0xFFFFF800, mem_address + 0x14); //Set the start address for the next descriptor.  
writel (mem_address, 0x03002000+ 0x100 + 0x08); //Set the start address for the DMA channel0 descriptor.  
  
do {  
    If (mem_address == readl (0x03002000+ 0x100 + 0x08));  
    break;  
} while (1); //Make sure that the writing operation is valid.  
writel (0x00000001, 0x03002000+ 0x100 + 0x00); // Enable DMA channel0 transfer.
```

The DMAC supports increasing data package in transfer, pay attention to the following points:

- The 0xFFFFF800 value of [DMAC\\_FDESC\\_ADDR\\_REG](#) indicates that the DMA channel has got back the descriptor of the last package. The DMA channel will automatically stop the data transfer after transferring the current package.
- To add a package during the data transfer, check if the DMA channel has got back the descriptor of the last package. If yes, you cannot add any package in the current queue. Request another DMA channel with a new DRQ to transfer the package. Otherwise, you can add the package by modifying the [DMAC\\_FDESC\\_ADDR\\_REG](#) of the last package from 0xFFFFF800 to the start address of the to-be-added package.

To ensure that the modification is valid, read the value of [DMAC\\_FDESC\\_ADDR\\_REG](#) after the modification. The value 0xFFFFF800 indicates the modification fails and the other values indicate you have successfully added packages to the queue.

Another problem is, the system needs some time to process the modification, during which the DMA channel may get back the descriptor of the last package. You can read [DMAC\\_CUR\\_SRC\\_REG](#) and [DMAC\\_CUR\\_DEST\\_REG](#) and check if the increasing memory address accords with the information of the added package. If yes, the package is added successfully; otherwise, the modification failed.

To ensure a higher rate of success, it is suggested that you add the package before the half package interrupt of the penultimate package.

## 2.6.5 Register List

| Module Name | Base Address | Comments                                |
|-------------|--------------|-----------------------------------------|
| DMAC        | 0x0300 2000  |                                         |
| MCU_DMAC    | 0x0712 1000  | MCU_DMAC register is the same with DMAC |

| Register Name       | Offset                      | Description                                       |
|---------------------|-----------------------------|---------------------------------------------------|
| DMAC_IRQ_EN_REG0    | 0x0000                      | DMAC IRQ Enable Register 0                        |
| DMAC_IRQ_EN_REG1    | 0x0004                      | DMAC IRQ Enable Register 1                        |
| DMAC_IRQ_PEND_REG0  | 0x0010                      | DMAC IRQ Pending Status Register 0                |
| DMAC_IRQ_PEND_REG1  | 0x0014                      | DMAC IRQ Pending Status Register 1                |
| DMAC_SEC_REG        | 0x0020                      | DMAC Security Register                            |
| DMAC_AUTO_GATE_REG  | 0x0028                      | DMAC Auto Gating Register                         |
| DMAC_STA_REG        | 0x0030                      | DMAC Status Register                              |
| DMAC_IRQ_CPU_EN_REG | 0x0034                      | DMAC IRQ Transfer to CPU Field Enable Register    |
| DMAC_IRQ_MCU_EN_REG | 0x0038                      | DMAC IRQ Transfer to MCU Field Enable Register    |
| DMAC_EN_REG         | 0x0100+N*0x0040<br>(N=0-15) | DMAC Channel Enable Register                      |
| DMAC_PAU_REG        | 0x0104+N*0x0040<br>(N=0-15) | DMAC Channel Pause Register                       |
| DMAC_DESC_ADDR_REG  | 0x0108+N*0x0040<br>(N=0-15) | DMAC Channel Descriptor Address Register          |
| DMAC_CFG_REG        | 0x010C+N*0x0040<br>(N=0-15) | DMAC Channel Configuration Register               |
| DMAC_CUR_SRC_REG    | 0x0110+N*0x0040<br>(N=0-15) | DMAC Channel Current Source Address Register      |
| DMAC_CUR_DEST_REG   | 0x0114+N*0x0040<br>(N=0-15) | DMAC Channel Current Destination Address Register |
| DMAC_BCNT_LEFT_REG  | 0x0118+N*0x0040<br>(N=0-15) | DMAC Channel Byte Counter Left Register           |
| DMAC_PARA_REG       | 0x011C+N*0x0040<br>(N=0-15) | DMAC Channel Parameter Register                   |

| Register Name       | Offset                      | Description                             |
|---------------------|-----------------------------|-----------------------------------------|
| DMAC_MODE_REG       | 0x0128+N*0x0040<br>(N=0-15) | DMAC Mode Register                      |
| DMAC_FDESC_ADDR_REG | 0x012C+N*0x0040<br>(N=0-15) | DMAC Former Descriptor Address Register |
| DMAC_PKG_NUM_REG    | 0x0130+N*0x0040<br>(N=0-15) | DMAC Package Number Register            |

## 2.6.6 Register Description

### 2.6.6.1 0x0000 DMAC IRQ Enable Register 0 (Default Value: 0x0000\_0000)

| Offset: 0x0000 |            |             | Register Name: DMAC_IRQ_EN_REG0                                                              |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                  |
| 31             | R/W        | 0x0         | DMA7_TIMEOUT_IRQ_EN<br>DMA 7 Timeout Interrupt Enable.<br>0: Disable<br>1: Enable            |
| 30             | R/W        | 0x0         | DMA7_QUEUE_IRQ_EN<br>DMA 7 Queue End Transfer Interrupt Enable.<br>0: Disable<br>1: Enable   |
| 29             | R/W        | 0x0         | DMA7_PKG_IRQ_EN<br>DMA 7 Package End Transfer Interrupt Enable.<br>0: Disable<br>1: Enable   |
| 28             | R/W        | 0x0         | DMA7_HLAF_IRQ_EN<br>DMA 7 Half Package Transfer Interrupt Enable.<br>0: Disable<br>1: Enable |
| 27             | R/W        | 0x0         | DMA6_TIMEOUT_IRQ_EN<br>DMA 6 Timeout Interrupt Enable.<br>0: Disable<br>1: Enable            |
| 26             | R/W        | 0x0         | DMA6_QUEUE_IRQ_EN<br>DMA 6 Queue End Transfer Interrupt Enable.<br>0: Disable<br>1: Enable   |
| 25             | R/W        | 0x0         | DMA6_PKG_IRQ_EN<br>DMA 6 Package End Transfer Interrupt Enable.<br>0: Disable<br>1: Enable   |
| 24             | R/W        | 0x0         | DMA6_HLAF_IRQ_EN                                                                             |

| Offset: 0x0000 |            |             | Register Name: DMAC_IRQ_EN_REG0                                                              |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                  |
|                |            |             | DMA 6 Half Package Transfer Interrupt Enable.<br>0: Disable<br>1: Enable                     |
| 23             | R/W        | 0x0         | DMA5_TIMEOUT_IRQ_EN<br>DMA 5 Timeout Interrupt Enable.<br>0: Disable<br>1: Enable            |
| 22             | R/W        | 0x0         | DMA5_QUEUE_IRQ_EN<br>DMA 5 Queue End Transfer Interrupt Enable.<br>0: Disable<br>1: Enable   |
| 21             | R/W        | 0x0         | DMA5_PKG_IRQ_EN<br>DMA 5 Package End Transfer Interrupt Enable.<br>0: Disable<br>1: Enable   |
| 20             | R/W        | 0x0         | DMA5_HLAF_IRQ_EN<br>DMA 5 Half package Transfer Interrupt Enable.<br>0: Disable<br>1: Enable |
| 19             | R/W        | 0x0         | DMA4_TIMEOUT_IRQ_EN<br>DMA 4 Timeout Interrupt Enable.<br>0: Disable<br>1: Enable            |
| 18             | R/W        | 0x0         | DMA4_QUEUE_IRQ_EN<br>DMA 4 Queue End Transfer Interrupt Enable.<br>0: Disable<br>1: Enable   |
| 17             | R/W        | 0x0         | DMA4_PKG_IRQ_EN<br>DMA 4 Package End Transfer Interrupt Enable.<br>0: Disable<br>1: Enable   |
| 16             | R/W        | 0x0         | DMA4_HLAF_IRQ_EN<br>DMA 4 Half Package Transfer Interrupt Enable.<br>0: Disable<br>1: Enable |
| 15             | R/W        | 0x0         | DMA3_TIMEOUT_IRQ_EN<br>DMA 3 Timeout Interrupt Enable.<br>0: Disable<br>1: Enable            |
| 14             | R/W        | 0x0         | DMA3_QUEUE_IRQ_EN<br>DMA 3 Queue End Transfer Interrupt Enable.                              |

| Offset: 0x0000 |            |             | Register Name: DMAC IRQ_EN_REG0                                                              |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                  |
|                |            |             | 0: Disable<br>1: Enable                                                                      |
| 13             | R/W        | 0x0         | DMA3_PKG_IRQ_EN<br>DMA 3 Package End Transfer Interrupt Enable.<br>0: Disable<br>1: Enable   |
| 12             | R/W        | 0x0         | DMA3_HLAF_IRQ_EN<br>DMA 3 Half Package Transfer Interrupt Enable.<br>0: Disable<br>1: Enable |
| 11             | R/W        | 0x0         | DMA2_TIMEOUT_IRQ_EN<br>DMA 2 Timeout Interrupt Enable.<br>0: Disable<br>1: Enable            |
| 10             | R/W        | 0x0         | DMA2_QUEUE_IRQ_EN<br>DMA 2 Queue End Transfer Interrupt Enable.<br>0: Disable<br>1: Enable   |
| 9              | R/W        | 0x0         | DMA2_PKG_IRQ_EN<br>DMA 2 Package End Transfer Interrupt Enable.<br>0: Disable<br>1: Enable   |
| 8              | R/W        | 0x0         | DMA2_HLAF_IRQ_EN<br>DMA 2 Half Package Transfer Interrupt Enable.<br>0: Disable<br>1: Enable |
| 7              | R/W        | 0x0         | DMA1_TIMEOUT_IRQ_EN<br>DMA 1 Timeout Interrupt Enable.<br>0: Disable<br>1: Enable            |
| 6              | R/W        | 0x0         | DMA1_QUEUE_IRQ_EN<br>DMA 1 Queue End Transfer Interrupt Enable.<br>0: Disable<br>1: Enable   |
| 5              | R/W        | 0x0         | DMA1_PKG_IRQ_EN<br>DMA 1 Package End Transfer Interrupt Enable.<br>0: Disable<br>1: Enable   |
| 4              | R/W        | 0x0         | DMA1_HLAF_IRQ_EN<br>DMA 1 Half Package Transfer Interrupt Enable.<br>0: Disable              |

| Offset: 0x0000 |            |             | Register Name: DMAC_IRQ_EN_REG0                                                              |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                  |
|                |            |             | 1: Enable                                                                                    |
| 3              | R/W        | 0x0         | DMA0_TIMEOUT_IRQ_EN<br>DMA 0 Timeout Interrupt Enable.<br>0: Disable<br>1: Enable            |
| 2              | R/W        | 0x0         | DMA0_QUEUE_IRQ_EN<br>DMA 0 Queue End Transfer Interrupt Enable.<br>0: Disable<br>1: Enable   |
| 1              | R/W        | 0x0         | DMA0_PKG_IRQ_EN<br>DMA 0 Package End Transfer Interrupt Enable.<br>0: Disable<br>1: Enable   |
| 0              | R/W        | 0x0         | DMA0_HLAF_IRQ_EN<br>DMA 0 Half Package Transfer Interrupt Enable.<br>0: Disable<br>1: Enable |

#### 2.6.6.2 0x0004 DMAC IRQ Enable Register 1 (Default Value: 0x0000\_0000)

| Offset: 0x0004 |            |             | Register Name: DMAC_IRQ_EN_REG1                                                                |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                    |
| 31             | R/W        | 0x0         | DMA15_TIMEOUT_IRQ_EN<br>DMA 15 Timeout Interrupt Enable.<br>0: Disable<br>1: Enable            |
| 30             | R/W        | 0x0         | DMA15_QUEUE_IRQ_EN<br>DMA 15 Queue End Transfer Interrupt Enable.<br>0: Disable<br>1: Enable   |
| 29             | R/W        | 0x0         | DMA15_PKG_IRQ_EN<br>DMA 15 Package End Transfer Interrupt Enable.<br>0: Disable<br>1: Enable   |
| 28             | R/W        | 0x0         | DMA15_HLAF_IRQ_EN<br>DMA 15 Half Package Transfer Interrupt Enable.<br>0: Disable<br>1: Enable |
| 27             | R/W        | 0x0         | DMA14_TIMEOUT_IRQ_EN<br>DMA 14 Timeout Interrupt Enable.<br>0: Disable                         |

| Offset: 0x0004 |            |             | Register Name: DMAC_IRQ_EN_REG1                                                                |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                    |
|                |            |             | 1: Enable                                                                                      |
| 26             | R/W        | 0x0         | DMA14_QUEUE_IRQ_EN<br>DMA 14 Queue End Transfer Interrupt Enable.<br>0: Disable<br>1: Enable   |
| 25             | R/W        | 0x0         | DMA14_PKG_IRQ_EN<br>DMA 14 Package End Transfer Interrupt Enable.<br>0: Disable<br>1: Enable   |
| 24             | R/W        | 0x0         | DMA14_HLAF_IRQ_EN<br>DMA 14 Half Package Transfer Interrupt Enable.<br>0: Disable<br>1: Enable |
| 23             | R/W        | 0x0         | DMA13_TIMEOUT_IRQ_EN<br>DMA 13 Timeout Interrupt Enable.<br>0: Disable<br>1: Enable            |
| 22             | R/W        | 0x0         | DMA13_QUEUE_IRQ_EN<br>DMA 13 Queue End Transfer Interrupt Enable.<br>0: Disable<br>1: Enable   |
| 21             | R/W        | 0x0         | DMA13_PKG_IRQ_EN<br>DMA 13 Package End Transfer Interrupt Enable.<br>0: Disable<br>1: Enable   |
| 20             | R/W        | 0x0         | DMA13_HLAF_IRQ_EN<br>DMA 13 Half package Transfer Interrupt Enable.<br>0: Disable<br>1: Enable |
| 19             | R/W        | 0x0         | DMA12_TIMEOUT_IRQ_EN<br>DMA 12 Timeout Interrupt Enable.<br>0: Disable<br>1: Enable            |
| 18             | R/W        | 0x0         | DMA12_QUEUE_IRQ_EN<br>DMA 12 Queue End Transfer Interrupt Enable.<br>0: Disable<br>1: Enable   |
| 17             | R/W        | 0x0         | DMA12_PKG_IRQ_EN<br>DMA 12 Package End Transfer Interrupt Enable.<br>0: Disable<br>1: Enable   |

| Offset: 0x0004 |            |             | Register Name: DMAC_IRQ_EN_REG1                                                                |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                    |
| 16             | R/W        | 0x0         | DMA12_HLAF_IRQ_EN<br>DMA 12 Half Package Transfer Interrupt Enable.<br>0: Disable<br>1: Enable |
| 15             | R/W        | 0x0         | DMA11_TIMEOUT_IRQ_EN<br>DMA 11 Timeout Interrupt Enable.<br>0: Disable<br>1: Enable            |
| 14             | R/W        | 0x0         | DMA11_QUEUE_IRQ_EN<br>DMA 11 Queue End Transfer Interrupt Enable.<br>0: Disable<br>1: Enable   |
| 13             | R/W        | 0x0         | DMA11_PKG_IRQ_EN<br>DMA 11 Package End Transfer Interrupt Enable.<br>0: Disable<br>1: Enable   |
| 12             | R/W        | 0x0         | DMA11_HLAF_IRQ_EN<br>DMA 11 Half Package Transfer Interrupt Enable.<br>0: Disable<br>1: Enable |
| 11             | R/W        | 0x0         | DMA10_TIMEOUT_IRQ_EN<br>DMA 10 Timeout Interrupt Enable.<br>0: Disable<br>1: Enable            |
| 10             | R/W        | 0x0         | DMA10_QUEUE_IRQ_EN<br>DMA10 Queue End Transfer Interrupt Enable.<br>0: Disable<br>1: Enable    |
| 9              | R/W        | 0x0         | DMA10_PKG_IRQ_EN<br>DMA10 Package End Transfer Interrupt Enable.<br>0: Disable<br>1: Enable    |
| 8              | R/W        | 0x0         | DMA2_HLAF_IRQ_EN<br>DMA 2 Half Package Transfer Interrupt Enable.<br>0: Disable<br>1: Enable   |
| 7              | R/W        | 0x0         | DMA9_TIMEOUT_IRQ_EN<br>DMA 9 Timeout Interrupt Enable.<br>0: Disable<br>1: Enable              |
| 6              | R/W        | 0x0         | DMA9_QUEUE_IRQ_EN                                                                              |

| Offset: 0x0004 |            |             | Register Name: DMAC_IRQ_EN_REG1                                                             |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                 |
|                |            |             | DMA9 Queue End Transfer Interrupt Enable.<br>0: Disable<br>1: Enable                        |
| 5              | R/W        | 0x0         | DMA9_PKG_IRQ_EN<br>DMA9 Package End Transfer Interrupt Enable.<br>0: Disable<br>1: Enable   |
| 4              | R/W        | 0x0         | DMA9_HLAF_IRQ_EN<br>DMA9 Half Package Transfer Interrupt Enable.<br>0: Disable<br>1: Enable |
| 3              | R/W        | 0x0         | DMA8_TIMEOUT_IRQ_EN<br>DMA 8 Timeout Interrupt Enable.<br>0: Disable<br>1: Enable           |
| 2              | R/W        | 0x0         | DMA8_QUEUE_IRQ_EN<br>DMA8 Queue End Transfer Interrupt Enable.<br>0: Disable<br>1: Enable   |
| 1              | R/W        | 0x0         | DMA8_PKG_IRQ_EN<br>DMA8 Package End Transfer Interrupt Enable.<br>0: Disable<br>1: Enable   |
| 0              | R/W        | 0x0         | DMA8_HLAF_IRQ_EN<br>DMA8 Half Package Transfer Interrupt Enable.<br>0: Disable<br>1: Enable |

#### 2.6.6.3 0x0010 DMAC IRQ Pending Status Register 0 (Default Value: 0x0000\_0000)

| Offset: 0x0010 |            |             | Register Name: DMAC_IRQ_PEND_REG0                                                                                                 |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                       |
| 31             | R/W1C      | 0x0         | DMA7_TIMEOUT_IRQ_PEND<br>DMA 7 Timeout Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending           |
| 30             | R/W1C      | 0x0         | DMA7_QUEUE_IRQ_PEND.<br>DMA 7 Queue End Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending |

| Offset: 0x0010 |            |             | Register Name: DMAC IRQ PEND REG0                                                                                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                         |
| 29             | R/W1C      | 0x0         | DMA7_PKG_IRQ_PEND<br>DMA 7 Package End Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending    |
| 28             | R/W1C      | 0x0         | DMA7_HLAF_IRQ_PEND.<br>DMA 7 Half Package Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending |
| 27             | R/W1C      | 0x0         | DMA6_TIMEOUT_IRQ_PEND<br>DMA 6 Timeout Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending             |
| 26             | R/W1C      | 0x0         | DMA6_QUEUE_IRQ_PEND.<br>DMA 6 Queue End Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending   |
| 25             | R/W1C      | 0x0         | DMA6_PKG_IRQ_PEND<br>DMA 6 Package End Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending    |
| 24             | R/W1C      | 0x0         | DMA6_HLAF_IRQ_PEND.<br>DMA 6 Half Package Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending |
| 23             | R/W1C      | 0x0         | DMA5_TIMEOUT_IRQ_PEND<br>DMA 5 Timeout Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending             |
| 22             | R/W1C      | 0x0         | DMA5_QUEUE_IRQ_PEND.<br>DMA 5 Queue End Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending   |
| 21             | R/W1C      | 0x0         | DMA5_PKG_IRQ_PEND<br>DMA 5 Package End Transfer Interrupt Pending. Set 1 to the bit will clear it.                                  |

| Offset: 0x0010 |            |             | Register Name: DMAC_IRQ_PEND_REG0                                                                                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                         |
|                |            |             | 0: No effect<br>1: Pending                                                                                                          |
| 20             | R/W1C      | 0x0         | DMA5_HLAF_IRQ_PEND.<br>DMA 5 Half Package Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending |
| 19             | R/W1C      | 0x0         | DMA4_TIMEOUT_IRQ_PEND<br>DMA 4 Timeout Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending             |
| 18             | R/W1C      | 0x0         | DMA4_QUEUE_IRQ_PEND.<br>DMA 4 Queue End Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending   |
| 17             | R/W1C      | 0x0         | DMA4_PKG_IRQ_PEND<br>DMA 4 Package End Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending    |
| 16             | R/W1C      | 0x0         | DMA4_HLAF_IRQ_PEND.<br>DMA 4 Half Package Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending |
| 15             | R/W1C      | 0x0         | DMA3_TIMEOUT_IRQ_PEND<br>DMA 3 Timeout Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending             |
| 14             | R/W1C      | 0x0         | DMA3_QUEUE_IRQ_PEND.<br>DMA 3 Queue End Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect, 1: Pending.    |
| 13             | R/W1C      | 0x0         | DMA3_PKG_IRQ_PEND<br>DMA 3 Package End Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending    |
| 12             | R/W1C      | 0x0         | DMA3_HLAF_IRQ_PEND.<br>DMA 3 Half Package Transfer Interrupt Pending. Set 1 to the                                                  |

| Offset: 0x0010 |            |             | Register Name: DMAC_IRQ_PEND_REG0                                                                                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                         |
|                |            |             | bit will clear it.<br>0: No effect<br>1: Pending                                                                                    |
| 11             | R/W1C      | 0x0         | DMA2_TIMEOUT_IRQ_PEND<br>DMA 2 Timeout Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending             |
| 10             | R/W1C      | 0x0         | DMA2_QUEUE_IRQ_PEND.<br>DMA 2 Queue End Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending   |
| 9              | R/W1C      | 0x0         | DMA2_PKG_IRQ_PEND<br>DMA 2 Package End Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending    |
| 8              | R/W1C      | 0x0         | DMA2_HLAF_IRQ_PEND.<br>DMA 2 Half Package Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending |
| 7              | R/W1C      | 0x0         | DMA1_TIMEOUT_IRQ_PEND<br>DMA 1 Timeout Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending             |
| 6              | R/W1C      | 0x0         | DMA1_QUEUE_IRQ_PEND.<br>DMA 1 Queue End Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending   |
| 5              | R/W1C      | 0x0         | DMA1_PKG_IRQ_PEND<br>DMA 1 Package End Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending    |
| 4              | R/W1C      | 0x0         | DMA1_HLAF_IRQ_PEND.<br>DMA 1 Half Package Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending |

| Offset: 0x0010 |            |             | Register Name: DMAC_IRQ_PEND_REG0                                                                                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                         |
| 3              | R/W1C      | 0x0         | DMA0_TIMEOUT_IRQ_PEND<br>DMA 0 Timeout Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending             |
| 2              | R/W1C      | 0x0         | DMA0_QUEUE_IRQ_PEND.<br>DMA 0 Queue End Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending   |
| 1              | R/W1C      | 0x0         | DMA0_PKG_IRQ_PEND<br>DMA 0 Package End Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending    |
| 0              | R/W1C      | 0x0         | DMA0_HLAF_IRQ_PEND.<br>DMA 0 Half Package Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending |

#### 2.6.6.4 0x0014 DMAC IRQ Pending Status Register 1 (Default Value: 0x0000\_0000)

| Offset: 0x0014 |            |             | Register Name: DMAC_IRQ_PEND_REG1                                                                                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                         |
| 31             | R/W1C      | 0x0         | DMA15_TIMEOUT_IRQ_PEND<br>DMA 15 Timeout Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending           |
| 30             | R/W1C      | 0x0         | DMA15_QUEUE_IRQ_PEND.<br>DMA 15 Queue End Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending |
| 29             | R/W1C      | 0x0         | DMA15_PKG_IRQ_PEND<br>DMA 15 Package End Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending  |
| 28             | R/W1C      | 0x0         | DMA15_HLAF_IRQ_PEND.<br>DMA 15 Half Package Transfer Interrupt Pending. Set 1 to the                                                |

| Offset: 0x0014 |            |             | Register Name: DMAC_IRQ_PEND_REG1                                                                                                     |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                           |
|                |            |             | bit will clear it.<br>0: No effect<br>1: Pending                                                                                      |
| 27             | R/W1C      | 0x0         | DMA14_TIMEOUT_IRQ_PEND<br>DMA 14 Timeout Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending             |
| 26             | R/W1C      | 0x0         | DMA14_QUEUE_IRQ_PEND.<br>DMA 14 Queue End Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending   |
| 25             | R/W1C      | 0x0         | DMA14_PKG_IRQ_PEND<br>DMA 14 Package End Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending    |
| 24             | R/W1C      | 0x0         | DMA14_HLAF_IRQ_PEND.<br>DMA 14 Half Package Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending |
| 23             | R/W1C      | 0x0         | DMA13_TIMEOUT_IRQ_PEND<br>DMA 13 Timeout Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending             |
| 22             | R/W1C      | 0x0         | DMA13_QUEUE_IRQ_PEND.<br>DMA 13 Queue End Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending   |
| 21             | R/W1C      | 0x0         | DMA13_PKG_IRQ_PEND<br>DMA 13 Package End Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending    |
| 20             | R/W1C      | 0x0         | DMA13_HLAF_IRQ_PEND.<br>DMA 13 Half Package Transfer Interrupt Pending. Set 1 to the bit will clear it.                               |

| Offset: 0x0014 |            |             | Register Name: DMAC IRQ_PEND_REG1                                                                                                     |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                           |
|                |            |             | 0: No effect<br>1: Pending                                                                                                            |
| 19             | R/W1C      | 0x0         | DMA12_TIMEOUT_IRQ_PEND<br>DMA 12 Timeout Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending             |
| 18             | R/W1C      | 0x0         | DMA12_QUEUE_IRQ_PEND.<br>DMA 12 Queue End Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending   |
| 17             | R/W1C      | 0x0         | DMA12_PKG_IRQ_PEND<br>DMA 12 Package End Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending    |
| 16             | R/W1C      | 0x0         | DMA12_HLAF_IRQ_PEND.<br>DMA 12 Half Package Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending |
| 15             | R/W1C      | 0x0         | DMA11_TIMEOUT_IRQ_PEND<br>DMA 11 Timeout Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending             |
| 14             | R/W1C      | 0x0         | DMA11_QUEUE_IRQ_PEND.<br>DMA 11 Queue End Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect, 1: Pending.    |
| 13             | R/W1C      | 0x0         | DMA11_PKG_IRQ_PEND<br>DMA 11 Package End Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending    |
| 12             | R/W1C      | 0x0         | DMA11_HLAF_IRQ_PEND.<br>DMA 11 Half Package Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending |

| Offset: 0x0014 |            |             | Register Name: DMAC IRQ_PEND_REG1                                                                                                     |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                           |
| 11             | R/W1C      | 0x0         | DMA10_TIMEOUT_IRQ_PEND<br>DMA 10 Timeout Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending             |
| 10             | R/W1C      | 0x0         | DMA10_QUEUE_IRQ_PEND.<br>DMA 10 Queue End Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending   |
| 9              | R/W1C      | 0x0         | DMA10_PKG_IRQ_PEND<br>DMA 10 Package End Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending    |
| 8              | R/W1C      | 0x0         | DMA10_HLAF_IRQ_PEND.<br>DMA 10 Half Package Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending |
| 7              | R/W1C      | 0x0         | DMA9_TIMEOUT_IRQ_PEND<br>DMA 9 Timeout Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending               |
| 6              | R/W1C      | 0x0         | DMA9_QUEUE_IRQ_PEND.<br>DMA 9 Queue End Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending     |
| 5              | R/W1C      | 0x0         | DMA9_PKG_IRQ_PEND<br>DMA 9 Package End Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending      |
| 4              | R/W1C      | 0x0         | DMA9_HLAF_IRQ_PEND.<br>DMA 9 Half Package Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending   |
| 3              | R/W1C      | 0x0         | DMA8_TIMEOUT_IRQ_PEND<br>DMA 8 Timeout Interrupt Pending. Set 1 to the bit will clear it.                                             |

| Offset: 0x0014 |            |             | Register Name: DMAC IRQ_PEND_REG1                                                                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                        |
|                |            |             | 0: No effect<br>1: Pending                                                                                                         |
| 2              | R/W1C      | 0x0         | DMA8_QUEUE_IRQ_PEND.<br>DMA8 Queue End Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending   |
| 1              | R/W1C      | 0x0         | DMA8_PKG_IRQ_PEND<br>DMA 8 Package End Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending   |
| 0              | R/W1C      | 0x0         | DMA8_HLAF_IRQ_PEND.<br>DMA8 Half Package Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending |

#### 2.6.6.5 0x0020 DMAC Security Register (Default Value: 0x0000\_FFFF)

| Offset: 0x0020 |            |             | Register Name: DMAC_SEC_REG                                           |
|----------------|------------|-------------|-----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                           |
| 31:16          | /          | /           | /                                                                     |
| 15             | R/W        | 0x1         | DMA15_SEC<br>DMA channel 15 security.<br>0: Secure,<br>1: Non-secure. |
| 14             | R/W        | 0x1         | DMA14_SEC<br>DMA channel 14 security.<br>0: Secure,<br>1: Non-secure. |
| 13             | R/W        | 0x1         | DMA13_SEC<br>DMA channel 13 security.<br>0: Secure,<br>1: Non-secure. |
| 12             | R/W        | 0x1         | DMA12_SEC<br>DMA channel 12 security.<br>0: Secure,<br>1: Non-secure. |
| 11             | R/W        | 0x1         | DMA11_SEC<br>DMA channel 11 security.                                 |

| Offset: 0x0020 |            |             | Register Name: DMAC_SEC_REG                                           |
|----------------|------------|-------------|-----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                           |
|                |            |             | 0: Secure,<br>1: Non-secure.                                          |
| 10             | R/W        | 0x1         | DMA10_SEC<br>DMA channel 10 security.<br>0: Secure,<br>1: Non-secure. |
| 9              | R/W        | 0x1         | DMA9_SEC<br>DMA channel 9 security.<br>0: Secure,<br>1: Non-secure.   |
| 8              | R/W        | 0x1         | DMA8_SEC<br>DMA channel 8 security.<br>0: Secure,<br>1: Non-secure.   |
| 7              | R/W        | 0x1         | DMA7_SEC<br>DMA channel 7 security.<br>0: Secure,<br>1: Non-secure.   |
| 6              | R/W        | 0x1         | DMA6_SEC<br>DMA channel 6 security.<br>0: Secure,<br>1: Non-secure.   |
| 5              | R/W        | 0x1         | DMA5_SEC<br>DMA channel 5 security.<br>0: Secure,<br>1: Non-secure.   |
| 4              | R/W        | 0x1         | DMA4_SEC<br>DMA channel 4 security.<br>0: Secure,<br>1: Non-secure.   |
| 3              | R/W        | 0x1         | DMA3_SEC<br>DMA channel 3 security.<br>0: Secure,<br>1: Non-secure.   |
| 2              | R/W        | 0x1         | DMA2_SEC<br>DMA channel 2 security.<br>0: Secure,<br>1: Non-secure.   |
| 1              | R/W        | 0x1         | DMA1_SEC<br>DMA channel 1 security.<br>0: Secure,                     |

| Offset: 0x0020 |            |             | Register Name: DMAC_SEC_REG                                         |
|----------------|------------|-------------|---------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                         |
|                |            |             | 1: Non-secure.                                                      |
| 0              | R/W        | 0x1         | DMA0_SEC<br>DMA channel 0 security.<br>0: Secure,<br>1: Non-secure. |

#### 2.6.6.6 0x0028 DMAC Auto Gating Register (Default Value: 0x00000000)

| Offset: 0x0028 |            |             | Register Name: DMAC_AUTO_GATE_REG                                                                                   |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                         |
| 31:3           | /          | /           | /                                                                                                                   |
| 2              | R/W        | 0x0         | DMA_MCLK_CIRCUIT.<br>DMA MCLK interface circuit auto gating bit.<br>0: Auto gating enable<br>1: Auto gating disable |
| 1              | R/W        | 0x0         | DMA_COMMON_CIRCUIT.<br>DMA common circuit auto gating bit.<br>0: Auto gating enable<br>1: Auto gating disable       |
| 0              | R/W        | 0x0         | DMA_CHAN_CIRCUIT.<br>DMA channel circuit auto gating bit.<br>0: Auto gating enable<br>1: Auto gating disable        |



#### NOTE

When initializing DMA Controller, bit-2 should be set up.

#### 2.6.6.7 0x0030 DMAC Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0030 |            |             | Register Name: DMAC_STA_REG                                      |
|----------------|------------|-------------|------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                      |
| 31             | R          | 0           | MBUS_FIFO_STATUS<br>MBUS FIFO Status<br>0: Empty<br>1: Not Empty |
| 30:16          | /          | /           | /                                                                |
| 15             | R          | 0x0         | DMA15_STATUS<br>DMA Channel 15 Status.                           |

| Offset: 0x0030 |            |             | Register Name: DMAC_STA_REG                                  |
|----------------|------------|-------------|--------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                  |
|                |            |             | 0: Idle<br>1: Busy                                           |
| 14             | R          | 0x0         | DMA14_STATUS<br>DMA Channel 14 Status.<br>0: Idle<br>1: Busy |
| 13             | R          | 0x0         | DMA13_STATUS<br>DMA Channel 13 Status.<br>0: Idle<br>1: Busy |
| 12             | R          | 0x0         | DMA12_STATUS<br>DMA Channel 12 Status.<br>0: Idle<br>1: Busy |
| 11             | R          | 0x0         | DMA11_STATUS<br>DMA Channel 11 Status.<br>0: Idle<br>1: Busy |
| 10             | R          | 0x0         | DMA10_STATUS<br>DMA Channel 10 Status.<br>0: Idle<br>1: Busy |
| 9              | R          | 0x0         | DMA9_STATUS<br>DMA Channel 9 Status.<br>0: Idle<br>1: Busy   |
| 8              | R          | 0x0         | DMA8_STATUS<br>DMA Channel 8 Status.<br>0: Idle<br>1: Busy   |
| 7              | R          | 0x0         | DMA7_STATUS<br>DMA Channel 7 Status.<br>0: Idle<br>1: Busy   |
| 6              | R          | 0x0         | DMA6_STATUS<br>DMA Channel 6 Status.<br>0: Idle<br>1: Busy   |
| 5              | R          | 0x0         | DMA5_STATUS<br>DMA Channel 5 Status.<br>0: Idle              |

| Offset: 0x0030 |            |             | Register Name: DMAC_STA_REG                                |
|----------------|------------|-------------|------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                |
|                |            |             | 1: Busy                                                    |
| 4              | R          | 0x0         | DMA4_STATUS<br>DMA Channel 4 Status.<br>0: Idle<br>1: Busy |
| 3              | R          | 0x0         | DMA3_STATUS<br>DMA Channel 3 Status.<br>0: Idle<br>1: Busy |
| 2              | R          | 0x0         | DMA2_STATUS<br>DMA Channel 2 Status.<br>0: Idle<br>1: Busy |
| 1              | R          | 0x0         | DMA1_STATUS<br>DMA Channel 1 Status.<br>0: Idle<br>1: Busy |
| 0              | R          | 0x0         | DMA0_STATUS<br>DMA Channel 0 Status.<br>0: Idle<br>1: Busy |

#### 2.6.6.8 0x0034 DMAC IRQ Transfer to CPU Field Enable Register (Default Value: 0x0000\_FFFF)

| Offset: 0x0034 |            |             | Register Name: DMAC_IRQ_CPU_EN_REG                                                                                                                                      |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                             |
| 31:16          | /          | /           | /                                                                                                                                                                       |
| 15             | R/W        | 0x1         | DMA15_IRQ_CPU_EN<br>Control whether the DMA Channel 15 IRQ signal can transfer to CPU field or not.<br>0: can not transfer to CPU field<br>1: can transfer to CPU field |
| 14             | R/W        | 0x1         | DMA14_IRQ_CPU_EN<br>Control whether the DMA Channel 14 IRQ signal can transfer to CPU field or not.<br>0: can not transfer to CPU field<br>1: can transfer to CPU field |
| 13             | R/W        | 0x1         | DMA13_IRQ_CPU_EN<br>Control whether the DMA Channel 13 IRQ signal can transfer to CPU field or not.<br>0: can not transfer to CPU field                                 |

| Offset: 0x0034 |            |             | Register Name: DMAC IRQ_CPU_EN_REG                                                                                                                                      |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                             |
|                |            |             | 1: can transfer to CPU field                                                                                                                                            |
| 12             | R/W        | 0x1         | DMA12_IRQ_CPU_EN<br>Control whether the DMA Channel 12 IRQ signal can transfer to CPU field or not.<br>0: can not transfer to CPU field<br>1: can transfer to CPU field |
| 11             | R/W        | 0x1         | DMA11_IRQ_CPU_EN<br>Control whether the DMA Channel 11 IRQ signal can transfer to CPU field or not.<br>0: can not transfer to CPU field<br>1: can transfer to CPU field |
| 10             | R/W        | 0x1         | DMA10_IRQ_CPU_EN<br>Control whether the DMA Channel 10 IRQ signal can transfer to CPU field or not.<br>0: can not transfer to CPU field<br>1: can transfer to CPU field |
| 9              | R/W        | 0x1         | DMA9_IRQ_CPU_EN<br>Control whether the DMA Channel 9 IRQ signal can transfer to CPU field or not.<br>0: can not transfer to CPU field<br>1: can transfer to CPU field   |
| 8              | R/W        | 0x1         | DMA8_IRQ_CPU_EN<br>Control whether the DMA Channel 8 IRQ signal can transfer to CPU field or not.<br>0: can not transfer to CPU field<br>1: can transfer to CPU field   |
| 7              | R/W        | 0x1         | DMA7_IRQ_CPU_EN<br>Control whether the DMA Channel 7 IRQ signal can transfer to CPU field or not.<br>0: can not transfer to CPU field<br>1: can transfer to CPU field   |
| 6              | R/W        | 0x1         | DMA6_IRQ_CPU_EN<br>Control whether the DMA Channel 6 IRQ signal can transfer to CPU field or not.<br>0: can not transfer to CPU field<br>1: can transfer to CPU field   |
| 5              | R/W        | 0x1         | DMA5_IRQ_CPU_EN<br>Control whether the DMA Channel 5 IRQ signal can transfer to CPU field or not.<br>0: can not transfer to CPU field<br>1: can transfer to CPU field   |

| Offset: 0x0034 |            |             | Register Name: DMAC_IRQ_CPU_EN_REG                                                                                                                                    |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                           |
| 4              | R/W        | 0x1         | DMA4_IRQ_CPU_EN<br>Control whether the DMA Channel 4 IRQ signal can transfer to CPU field or not.<br>0: can not transfer to CPU field<br>1: can transfer to CPU field |
| 3              | R/W        | 0x1         | DMA3_IRQ_CPU_EN<br>Control whether the DMA Channel 3 IRQ signal can transfer to CPU field or not.<br>0: can not transfer to CPU field<br>1: can transfer to CPU field |
| 2              | R/W        | 0x1         | DMA2_IRQ_CPU_EN<br>Control whether the DMA Channel 2 IRQ signal can transfer to CPU field or not.<br>0: can not transfer to CPU field<br>1: can transfer to CPU field |
| 1              | R/W        | 0x1         | DMA1_IRQ_CPU_EN<br>Control whether the DMA Channel 1 IRQ signal can transfer to CPU field or not.<br>0: can not transfer to CPU field<br>1: can transfer to CPU field |
| 0              | R/W        | 0x1         | DMA0_IRQ_CPU_EN<br>Control whether the DMA Channel 0 IRQ signal can transfer to CPU field or not.<br>0: can not transfer to CPU field<br>1: can transfer to CPU field |

#### 2.6.6.9 0x0038 DMAC IRQ Transfer to MCU Field Enable Register (Default Value: 0x0000\_FFFF)

| Offset: 0x0038 |            |             | Register Name: DMAC_IRQ_MCU_EN_REG                                                                                                                                      |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                             |
| 31:16          | /          | /           | /                                                                                                                                                                       |
| 15             | R/W        | 0x1         | DMA15_IRQ_MCU_EN<br>Control whether the DMA Channel 15 IRQ signal can transfer to MCU field or not.<br>0: can not transfer to MCU field<br>1: can transfer to MCU field |
| 14             | R/W        | 0x1         | DMA14_IRQ_MCU_EN<br>Control whether the DMA Channel 14 IRQ signal can transfer to MCU field or not.<br>0: can not transfer to MCU field<br>1: can transfer to MCU field |

| Offset: 0x0038 |            |             | Register Name: DMAC_IRQ MCU_EN_REG                                                                                                                                      |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                             |
| 13             | R/W        | 0x1         | DMA13_IRQ_MCU_EN<br>Control whether the DMA Channel 13 IRQ signal can transfer to MCU field or not.<br>0: can not transfer to MCU field<br>1: can transfer to MCU field |
| 12             | R/W        | 0x1         | DMA12_IRQ_MCU_EN<br>Control whether the DMA Channel 12 IRQ signal can transfer to MCU field or not.<br>0: can not transfer to MCU field<br>1: can transfer to MCU field |
| 11             | R/W        | 0x1         | DMA11_IRQ_MCU_EN<br>Control whether the DMA Channel 11 IRQ signal can transfer to MCU field or not.<br>0: can not transfer to MCU field<br>1: can transfer to MCU field |
| 10             | R/W        | 0x1         | DMA10_IRQ_MCU_EN<br>Control whether the DMA Channel 10 IRQ signal can transfer to MCU field or not.<br>0: can not transfer to MCU field<br>1: can transfer to MCU field |
| 9              | R/W        | 0x1         | DMA9_IRQ_MCU_EN<br>Control whether the DMA Channel 9 IRQ signal can transfer to MCU field or not.<br>0: can not transfer to MCU field<br>1: can transfer to MCU field   |
| 8              | R/W        | 0x1         | DMA8_IRQ_MCU_EN<br>Control whether the DMA Channel 8 IRQ signal can transfer to MCU field or not.<br>0: can not transfer to MCU field<br>1: can transfer to MCU field   |
| 7              | R/W        | 0x1         | DMA7_IRQ_MCU_EN<br>Control whether the DMA Channel 7 IRQ signal can transfer to MCU field or not.<br>0: can not transfer to MCU field<br>1: can transfer to MCU field   |
| 6              | R/W        | 0x1         | DMA6_IRQ_MCU_EN<br>Control whether the DMA Channel 6 IRQ signal can transfer to MCU field or not.<br>0: can not transfer to MCU field<br>1: can transfer to MCU field   |
| 5              | R/W        | 0x1         | DMA5_IRQ_MCU_EN                                                                                                                                                         |

| Offset: 0x0038 |            |             | Register Name: DMAC_IRQ MCU_EN_REG                                                                                                                                                    |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                           |
|                |            |             | <p>Control whether the DMA Channel 5 IRQ signal can transfer to MCU field or not.</p> <p>0: can not transfer to MCU field<br/>1: can transfer to MCU field</p>                        |
| 4              | R/W        | 0x1         | <p>DMA4_IRQ MCU_EN</p> <p>Control whether the DMA Channel 4 IRQ signal can transfer to MCU field or not.</p> <p>0: can not transfer to MCU field<br/>1: can transfer to MCU field</p> |
| 3              | R/W        | 0x1         | <p>DMA3_IRQ MCU_EN</p> <p>Control whether the DMA Channel 3 IRQ signal can transfer to MCU field or not.</p> <p>0: can not transfer to MCU field<br/>1: can transfer to MCU field</p> |
| 2              | R/W        | 0x1         | <p>DMA2_IRQ MCU_EN</p> <p>Control whether the DMA Channel 2 IRQ signal can transfer to MCU field or not.</p> <p>0: can not transfer to MCU field<br/>1: can transfer to MCU field</p> |
| 1              | R/W        | 0x1         | <p>DMA1_IRQ MCU_EN</p> <p>Control whether the DMA Channel 1 IRQ signal can transfer to MCU field or not.</p> <p>0: can not transfer to MCU field<br/>1: can transfer to MCU field</p> |
| 0              | R/W        | 0x1         | <p>DMA0_IRQ MCU_EN</p> <p>Control whether the DMA Channel 0 IRQ signal can transfer to MCU field or not.</p> <p>0: can not transfer to MCU field<br/>1: can transfer to MCU field</p> |

#### 2.6.6.10 0x0100+N\*0x0040 (N=0-15) DMAC Channel Enable Register (Default Value: 0x0000\_0000)

| Offset: 0x0100+N*0x0040 (N=0-15) |            |             | Register Name: DMAC_EN_REG                                               |
|----------------------------------|------------|-------------|--------------------------------------------------------------------------|
| Bit                              | Read/Write | Default/Hex | Description                                                              |
| 31:1                             | /          | /           | /                                                                        |
| 0                                | R/W        | 0x0         | <p>DMA_EN.</p> <p>DMA Channel Enable</p> <p>0: Disable<br/>1: Enable</p> |

## 2.6.6.11 0x0104+N\*0x0040 (N=0-15) DMAC Channel Pause Register (Default Value: 0x0000\_0000)

| Offset: 0x0104+N*0x0040 (N=0-15) |            |             | Register Name: DMAC_PAU_REG                                                                         |
|----------------------------------|------------|-------------|-----------------------------------------------------------------------------------------------------|
| Bit                              | Read/Write | Default/Hex | Description                                                                                         |
| 31:1                             | /          | /           | /                                                                                                   |
| 0                                | R/W        | 0x0         | DMA_PAUSE.<br>Pausing DMA Channel Transfer Data.<br>0: Resume Transferring<br>1: Pause Transferring |

## 2.6.6.12 0x0108+N\*0x0040 (N=0-15) DMAC Channel Descriptor Address Register (Default Value: 0x0000\_0000)

| Offset: 0x0108+N*0x0040 (N=0-15) |            |             | Register Name: DMAC_DESC_ADDR_REG                                                                                                                                      |
|----------------------------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                              | Read/Write | Default/Hex | Description                                                                                                                                                            |
| 31:2                             | R/W        | 0x0         | DMA_DESC_LOW_ADDR<br>DMA Channel Descriptor Word Address, Low 30bits.<br>The Descriptor Address must be word-aligned.                                                  |
| 1:0                              | R/W        | 0x0         | DMA_DESC_HIGH_ADDR<br>DMA Channel Descriptor High Address, High 2bits<br>The real address is as below:<br>DMA Channel Descriptor Address = {bit[1:0],bit[31:2],2'b00}; |

## 2.6.6.13 0x010C+N\*0x0040 (N=0-15) DMAC Channel Configuration Register (Default Value: 0x0000\_0000)

| Offset: 0x010C+N*0x0040 (N=0-15) |            |             | Register Name: DMAC_CFG_REG                                                                                  |
|----------------------------------|------------|-------------|--------------------------------------------------------------------------------------------------------------|
| Bit                              | Read/Write | Default/Hex | Description                                                                                                  |
| 31                               | /          | /           | /                                                                                                            |
| 30                               | R          | 0x0         | BMODE_SEL<br>Mode select<br>0: Normal Mode<br>1: BMODE                                                       |
| 29:27                            | /          | /           | /                                                                                                            |
| 26:25                            | R          | 0x0         | DMA_DEST_DATA_WIDTH.<br>DMA Destination Data Width.<br>00: 8-bit<br>01: 16-bit<br>10: 32-bit<br>11: Reserved |

| Offset: 0x010C+N*0x0040 (N=0-15) |            |             | Register Name: DMAC_CFG_REG                                                                                |
|----------------------------------|------------|-------------|------------------------------------------------------------------------------------------------------------|
| Bit                              | Read/Write | Default/Hex | Description                                                                                                |
| 24                               | R          | 0x0         | DMA_ADDR_MODE.<br>DMA Destination Address Mode<br>0: Linear Mode<br>1: IO Mode                             |
| 23:22                            | R          | 0x0         | DMA_DEST_BLOCK_SIZE.<br>DMA Destination Block Size.<br>00: 1<br>01: 4<br>10: 8<br>11: 16                   |
| 21:16                            | R          | 0x0         | DMA_DEST_DRQ_TYPE.<br>DMA Destination DRQ Type<br>The details in DRQ Type and Port Corresponding Relation. |
| 15:11                            | /          | /           | /                                                                                                          |
| 10:9                             | R          | 0x0         | DMA_SRC_DATA_WIDTH.<br>DMA Source Data Width.<br>00: 8-bit<br>01: 16-bit<br>10: 32-bit<br>11: Reserved     |
| 8                                | R          | 0x0         | DMA_SRC_ADDR_MODE.<br>DMA Source Address Mode<br>0: Linear Mode<br>1: IO Mode                              |
| 7:6                              | R          | 0x0         | DMA_SRC_BLOCK_SIZE.<br>DMA Source Block Size.<br>00: 1<br>01: 4<br>10: 8<br>11: 16                         |
| 5:0                              | R          | 0x0         | DMA_SRC_DRQ_TYPE.<br>DMA Source DRQ Type<br>The details in DRQ Type and Port Corresponding Relation.       |

#### 2.6.6.14 0x0110+N\*0x0040 (N=0-15) DMAC Channel Current Source Address Register (Default Value: 0x0000\_0000)

| Offset: 0x0110+N*0x0040 (N=0-15) |            |             | Register Name: DMAC_CUR_SRC_REG |
|----------------------------------|------------|-------------|---------------------------------|
| Bit                              | Read/Write | Default/Hex | Description                     |
| 31:0                             | R          | 0x0         | DMA_CUR_SRC.                    |

| Offset: 0x0110+N*0x0040 (N=0-15) |            |             | Register Name: DMAC_CUR_SRC_REG                |
|----------------------------------|------------|-------------|------------------------------------------------|
| Bit                              | Read/Write | Default/Hex | Description                                    |
|                                  |            |             | DMA Channel Current Source Address, read only. |

2.6.6.15 0x0114+N\*0x0040 (N=0-15) DMAC Channel Current Destination Address Register (Default Value: 0x0000\_0000)

| Offset: 0x0114+N*0x0040 (N=0-15) |            |             | Register Name: DMAC_CUR_DEST_REG                                     |
|----------------------------------|------------|-------------|----------------------------------------------------------------------|
| Bit                              | Read/Write | Default/Hex | Description                                                          |
| 31:0                             | R          | 0x0         | DMA_CUR_DEST.<br>DMA Channel Current Destination Address, read only. |

2.6.6.16 0x0118+N\*0x0040 (N=0-15) DMAC Channel Byte Counter Left Register (Default Value: 0x0000\_0000)

| Offset: 0x0118+N*0x0040 (N=0-15) |            |             | Register Name: DMAC_BCNT_LEFT_REG                           |
|----------------------------------|------------|-------------|-------------------------------------------------------------|
| Bit                              | Read/Write | Default/Hex | Description                                                 |
| 31:25                            | /          | /           | /                                                           |
| 24:0                             | R          | 0x0         | DMA_BCNT_LEFT.<br>DMA Channel Byte Counter Left, read only. |

2.6.6.17 0x011C+N\*0x0040 (N=0-15) DMAC Channel Parameter Register (Default Value: 0x0000\_0000)



- The entered count number (bit [28:20], this number needs to be integer) = the time to be counted \* clock frequency (DMA clock frequency)/4096
- Take an example of 200MHz clock frequency for DMAC. If the step size of timer is 20.48 us, the longest counting time will be the maximum count\*step size=10.46 ms.

| Offset: 0x011C+N*0x0040 (N=0-15) |            |             | Register Name: DMAC_PARA_REG                                                                                |
|----------------------------------|------------|-------------|-------------------------------------------------------------------------------------------------------------|
| Bit                              | Read/Write | Default/Hex | Description                                                                                                 |
| 31                               | R          | 0x0         | DMA_TO_EN.<br>Timeout Function Enable Bit<br>1: Enable<br>0: Disable                                        |
| 30:29                            | R          | 0x0         | DMA_TO_FUN.<br>Timeout Function Configuration<br>01: Enabling pause channel transfer function after timeout |

| Offset: 0x011C+N*0x0040<br>(N=0-15) |            |             | Register Name: DMAC PARA_REG                                                                                      |
|-------------------------------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------|
| Bit                                 | Read/Write | Default/Hex | Description                                                                                                       |
|                                     |            |             | 10: Enabling stop channel transfer function after timeout<br>11: Enabling jump next opcode function after timeout |
| 28:20                               | R          | 0x0         | DMA_TO_WAIT_CYC.<br>The time cycle of waiting the start device to restart transferring data.                      |
| 19:18                               | R          | 0x0         | DMA Channel Current Destination Address[33:32], Read only.                                                        |
| 17:16                               | R          | 0x0         | DMA Channel Current Source Address[33:32], read only.                                                             |
| 15:9                                | /          | /           | /                                                                                                                 |
| 8                                   | R          | 0x0         | DMA_IOSPEED_EN.<br>Accelerating DMA speed when transferring the data of IO device 1: Enable 0: Disable            |
| 7:0                                 | R          | 0x0         | WAIT_CYC.<br>Wait Clock Cycles                                                                                    |

#### 2.6.6.18 0x0128+N\*0x0040 (N=0-15) DMAC Mode Register (Default Value: 0x0000\_0000)

| Offset: 0x0128+N*0x0040<br>(N=0-15) |     |             | Register Name: DMAC_MODE_REG                                                                                                                                                                                                                                                                        |
|-------------------------------------|-----|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                                 | R/W | Default/Hex | Description                                                                                                                                                                                                                                                                                         |
| 31:6                                | /   | /           | /                                                                                                                                                                                                                                                                                                   |
| 5                                   | R/W | 0x0         | LAG_TIME_MODE<br>In wait mode, enabling this bit, DMA will not timing wait cycle until DMA receive or transmit data successfully. It's recommend to enable this bit before using DMA when the DMA has enable more than one channel which access IO and memory equipment.<br>0: disable<br>1: enable |
| 4                                   | R/W | 0x0         | DMA_BLOCK_ZERO_EN<br>Enable pre-read source DRQ when source block is configured 0. It needs to disable when opening timeout sub function (DMA Channel Parameter Register [30:29] =01, 10 or 11) and source block is configured 0.<br>0: enable<br>1: disable                                        |
| 3                                   | R/W | 0x0         | DMA_DST_MODE.<br>Destination communication Mode Select<br>0: Wait mode.<br>1: Handshake mode.                                                                                                                                                                                                       |

| Offset: 0x0128+N*0x0040<br>(N=0-15) |     |             | Register Name: DMAC_MODE_REG                                                             |
|-------------------------------------|-----|-------------|------------------------------------------------------------------------------------------|
| Bit                                 | R/W | Default/Hex | Description                                                                              |
| 2                                   | R/W | 0x0         | DMA_SRC_MODE.<br>Source communication Mode Select<br>0: Wait mode.<br>1: Handshake mode. |
| 1:0                                 | /   | /           | /                                                                                        |

#### 2.6.6.19 0x012C+N\*0x0040 (N=0-15) DMAC Former Descriptor Address Register (Default Value: 0x0000\_0000)

| Offset: 0x012C+N*0x0040<br>(N=0-15) |            |             | Register Name: DMAC_FDESC_ADDR_REG                                                                               |
|-------------------------------------|------------|-------------|------------------------------------------------------------------------------------------------------------------|
| Bit                                 | Read/Write | Default/Hex | Description                                                                                                      |
| 31:0                                | R          | 0x0         | DMA_FDESC_ADDR.<br>This register is used to storing the former value of DMA Channel Descriptor Address Register. |

#### 2.6.6.20 0x0130+N\*0x0040 (N=0-15) DMAC Package Number Register (Default Value: 0x0000\_0000)

| Offset: 0x0130+N*0x0040<br>(N=0-15) |            |             | Register Name: DMAC_PKG_NUM_REG                                                                                |
|-------------------------------------|------------|-------------|----------------------------------------------------------------------------------------------------------------|
| Bit                                 | Read/Write | Default/Hex | Description                                                                                                    |
| 31:0                                | R          | 0x0         | DMA_PKG_NUM.<br>This register will record the number of packages which has been completed in one transmission. |

## 2.7 Generic Interrupt Controller (GIC)

### 2.7.1 Overview

The GIC-600 is a generic interrupt controller that handles interrupts from peripherals to the cores and interrupts between cores. The GIC-600 supports a distributed microarchitecture containing several individual blocks that are used to provide a flexible GIC implementation.

All the GIC-600 blocks communicate through fully credited AXI4-Stream interface channels. This means that the interface exerts transient backpressure only on their  $ic<xy>tready$  signals, enabling packets to be routed over any free-flowing interconnect. Channels can be routed over dedicated AXI4-Stream buses, or over any available free-flowing transport layer in the system. A channel is described as free-flowing if all transactions on that channel complete without a non-transient dependency on any other transaction.

The GIC-600 includes build scripts that can create appropriate levels of hierarchy for any particular configuration. In small configurations, the distribution can be hidden and internally optimized.

the GIC has the following features:

- Interrupt services and masking:
  - Supports the following interrupt types:
    - Up to 56000 LPIs. A peripheral generates these interrupts by writing to a memory-mapped register in the GIC-600.
    - Up to 960 SPIs in groups of 32.
    - Up to 16 PPIs that are independent for each core and can be programmed to support either edge triggered or level-sensitive interrupts.
    - Up to 16 SGIs that are generated through the GIC CPU interface of a core.
  - Up to 16 ITS modules that provide device isolation and ID translation for message-based interrupts and enable virtual machines to program devices directly.
  - Interrupt masking and prioritization with 32 priority levels, five bits per interrupt.
- Registers and programming
  - Flexible affinity routing, using the Multiprocessor Identification Register (MPIDR) addresses, including support for all four affinity levels.
  - Single ACE-Lite slave port on each chip for programming of all GIC Distributor (GICD) registers, GIC Interrupt Translation Service (GITS) registers, and GIC Redistributor (GICR) registers. Each ITS has an optional ACE-Lite slave port for programming the GITS\_TRANSLATER register.
  - Coherent view of SPI register data across multiple chips.

- Security
  - A global Disable Security (DS) bit. This bit enables support for systems without security.
  - The following interrupt groups allow interrupts to target different exception levels:
    - Group 0.
    - Non-secure Group 1.
    - Secure Group 1.
- Performance Monitoring Unit (PMU) counters with snapshot functionality.
- Error correction: ARMv8.2 Reliability Accessibility Serviceability (RAS) architecture-compliant error reporting for the following:
  - Software access errors
  - ITS command and translation errors
  - Error Correcting Code (ECC) errors

## 2.7.2 Functional Description

the following table describes the details of interrupt sources:

Table 2-15 Interrupt Source in CPUX Domain

| Interrupt Number | Interrupt Source | Interrupt Vector | Description      |
|------------------|------------------|------------------|------------------|
| 0                | SGI 0            | 0x0000           | SGI 0 interrupt  |
| 1                | SGI 1            | 0x0004           | SGI 1 interrupt  |
| 2                | SGI 2            | 0x0008           | SGI 2 interrupt  |
| 3                | SGI 3            | 0x000C           | SGI 3 interrupt  |
| 4                | SGI 4            | 0x0010           | SGI 4 interrupt  |
| 5                | SGI 5            | 0x0014           | SGI 5 interrupt  |
| 6                | SGI 6            | 0x0018           | SGI 6 interrupt  |
| 7                | SGI 7            | 0x001C           | SGI 7 interrupt  |
| 8                | SGI 8            | 0x0020           | SGI 8 interrupt  |
| 9                | SGI 9            | 0x0024           | SGI 9 interrupt  |
| 10               | SGI 10           | 0x0028           | SGI 10 interrupt |
| 11               | SGI 11           | 0x002C           | SGI 11 interrupt |
| 12               | SGI 12           | 0x0030           | SGI 12 interrupt |
| 13               | SGI 13           | 0x0034           | SGI 13 interrupt |
| 14               | SGI 14           | 0x0038           | SGI 14 interrupt |
| 15               | SGI 15           | 0x003C           | SGI 15 interrupt |
| 16               | PPI 0            | 0x0040           | PPI 0 interrupt  |
| 17               | PPI 1            | 0x0044           | PPI 1 interrupt  |
| 18               | PPI 2            | 0x0048           | PPI 2 interrupt  |
| 19               | PPI 3            | 0x004C           | PPI 3 interrupt  |
| 20               | PPI 4            | 0x0050           | PPI 4 interrupt  |

| Interrupt Number | Interrupt Source | Interrupt Vector | Description                    |
|------------------|------------------|------------------|--------------------------------|
| 21               | PPI 5            | 0x0054           | PPI 5 interrupt                |
| 22               | PPI 6            | 0x0058           | PPI 6 interrupt                |
| 23               | PPI 7            | 0x005C           | PPI 7 interrupt                |
| 24               | PPI 8            | 0x0060           | PPI 8 interrupt                |
| 25               | PPI 9            | 0x0064           | PPI 9 interrupt                |
| 26               | PPI 10           | 0x0068           | PPI 10 interrupt               |
| 27               | PPI 11           | 0x006C           | PPI 11 interrupt               |
| 28               | PPI 12           | 0x0070           | PPI 12 interrupt               |
| 29               | PPI 13           | 0x0074           | PPI 13 interrupt               |
| 30               | PPI 14           | 0x0078           | PPI 14 interrupt               |
| 31               | PPI 15           | 0x007C           | PPI 15 interrupt               |
| 32               | CPUX_MSGBOX_R    | 0x0080           | CPUX MSGBOX read IRQ for CPUX  |
| 33               | CPUS_MSGBOX_W    | 0x0084           | CPUS MSGBOX write IRQ for CPUX |
| 34               | UART0            | 0x0088           |                                |
| 35               | UART1            | 0x008C           |                                |
| 36               | UART2            | 0x0090           |                                |
| 37               | UART3            | 0x0094           |                                |
| 38               | UART4            | 0x0098           |                                |
| 39               | UART5            | 0x009C           |                                |
| 40               | UART6            | 0x00A0           |                                |
| 41               | UART7            | 0x00A4           |                                |
| 42               | TWI0             | 0x00A8           |                                |
| 43               | TWI1             | 0x00AC           |                                |
| 44               | TWI2             | 0x00B0           |                                |
| 45               | TWI3             | 0x00B4           |                                |
| 46               | TWI4             | 0x00B8           |                                |
| 47               | TWI5             | 0x00BC           |                                |
| 48               | SPI0             | 0x00C0           |                                |
| 49               | SPI1             | 0x00C4           |                                |
| 50               | SPI2             | 0x00C8           |                                |
| 51               | PWMCTRL0         | 0x00CC           |                                |
| 52               | SPIFC            | 0x00D0           |                                |
| 53               |                  | 0x00D4           |                                |
| 54               |                  | 0x00D8           |                                |
| 55               |                  | 0x00DC           |                                |
| 56               |                  | 0x00E0           |                                |
| 57               |                  | 0x00E4           |                                |
| 58               | CIR_TX           | 0x00E8           |                                |
| 59               | CIR_RX           | 0x00EC           |                                |
| 60               | LEDC             | 0x00F0           |                                |

| Interrupt Number | Interrupt Source        | Interrupt Vector | Description                               |
|------------------|-------------------------|------------------|-------------------------------------------|
| 61               | USB0_DEVICE             | 0x00F4           |                                           |
| 62               | USB0_EHCI               | 0x00F8           |                                           |
| 63               | USB0_OHCI               | 0x00FC           |                                           |
| 64               | USB1_EHCI               | 0x0100           |                                           |
| 65               | USB1_OHCI               | 0x0104           |                                           |
| 66               |                         | 0x0108           |                                           |
| 67               | USB2/USB3               | 0x010C           |                                           |
| 68               |                         | 0x0110           |                                           |
| 69               |                         | 0x0114           |                                           |
| 70               | NDFC                    | 0x0118           |                                           |
| 71               | THS0                    | 0x011C           |                                           |
| 72               | SMHC0                   | 0x0120           |                                           |
| 73               | SMHC1                   | 0x0124           |                                           |
| 74               | SMHC2                   | 0x0128           |                                           |
| 75               | NSI                     | 0x012C           |                                           |
| 76               | SMC                     | 0x0130           |                                           |
| 77               |                         | 0x0134           |                                           |
| 78               | GMAC                    | 0x0138           |                                           |
| 79               |                         | 0x013C           |                                           |
| 80               | CCU_FERR                | 0x0140           |                                           |
| 81               | AHB_HREADY_TI<br>ME_OUT | 0x0144           |                                           |
| 82               | DMAC_CPUX_NS            | 0x0148           | DMAC channel 0-15<br>non-secure interrupt |
| 83               | DMAC_CPUX_S             | 0x014C           | DMAC channel 0-15 secure<br>interrupt     |
| 84               | CE_NS                   | 0x0150           |                                           |
| 85               | CE_S                    | 0x0154           |                                           |
| 86               | SPINLOCK                | 0x0158           |                                           |
| 87               | CPUX_TIMER0             | 0x015C           |                                           |
| 88               | CPUX_TIMER1             | 0x0160           |                                           |
| 89               | CPUX_TIMER2             | 0x0164           |                                           |
| 90               | CPUX_TIMER3             | 0x0168           |                                           |
| 91               | CPUX_TIMER4             | 0x016C           |                                           |
| 92               | CPUX_TIMER5             | 0x0170           |                                           |
| 93               | GPADC                   | 0x0174           |                                           |
| 94               | THS1                    | 0x0178           |                                           |
| 95               | CPUX_WDT                | 0x017C           |                                           |
| 96               |                         | 0x0180           |                                           |
| 97               | IOMMU                   | 0x0184           |                                           |
| 98               | LRADC                   | 0x0188           |                                           |

| Interrupt Number | Interrupt Source | Interrupt Vector | Description |
|------------------|------------------|------------------|-------------|
| 99               | GPIOA_NS         | 0x018C           |             |
| 100              | GPIOA_S          | 0x0190           |             |
| 101              | GPIOB_NS         | 0x0194           |             |
| 102              | GPIOB_S          | 0x0198           |             |
| 103              | GPIOC_NS         | 0x019C           |             |
| 104              | GPIOC_S          | 0x01A0           |             |
| 105              | GPIOD_NS         | 0x01A4           |             |
| 106              | GPIOD_S          | 0x01A8           |             |
| 107              | GPIOE_NS         | 0x01AC           |             |
| 108              | GPIOE_S          | 0x01B0           |             |
| 109              | GPIOF_NS         | 0x01B4           |             |
| 110              | GPIOF_S          | 0x01B8           |             |
| 111              | GPIOG_NS         | 0x01BC           |             |
| 112              | GPIOG_S          | 0x01C0           |             |
| 113              | GPIOH_NS         | 0x01C4           |             |
| 114              | GPIOH_S          | 0x01C8           |             |
| 115              |                  | 0x01CC           |             |
| 116              |                  | 0x01D0           |             |
| 117              |                  | 0x01D4           |             |
| 118              |                  | 0x01D8           |             |
| 119              | DE               | 0x01DC           |             |
| 120              | DI               | 0x01E0           |             |
| 121              |                  | 0x01E4           |             |
| 122              | TCON_LCD0        | 0x01E8           |             |
| 123              |                  | 0x01EC           |             |
| 124              | TCON_LCD1        | 0x01F0           |             |
| 125              |                  | 0x01F4           |             |
| 126              | DSI0             | 0x01F8           |             |
| 127              | DSI1             | 0x01FC           |             |
| 128              | TCON_TV1         | 0x0200           |             |
| 129              |                  | 0x0204           |             |
| 130              | PCIE_EDMA[0]     | 0x0208           |             |
| 131              | PCIE_EDMA[1]     | 0x020C           |             |
| 132              | PCIE_EDMA[2]     | 0x0210           |             |
| 133              | PCIE_EDMA[0]     | 0x0214           |             |
| 134              | PCIE_EDMA[4]     | 0x0218           |             |
| 135              | PCIE_EDMA[5]     | 0x021C           |             |
| 136              | PCIE_EDMA[6]     | 0x0220           |             |
| 137              | PCIE_EDMA[7]     | 0x0224           |             |
| 138              | PCIE_SII         | 0x0228           |             |
| 139              | PCIE_MSI         | 0x022C           |             |

| Interrupt Number | Interrupt Source | Interrupt Vector | Description |
|------------------|------------------|------------------|-------------|
| 140              | PCIE_EDMA[8]     | 0x0230           |             |
| 141              | PCIE_EDMA[9]     | 0x0234           |             |
| 142              | PCIE_EDMA[10]    | 0x0238           |             |
| 143              | PCIE_EDMA[11]    | 0x023C           |             |
| 144              | PCIE_EDMA[12]    | 0x0240           |             |
| 145              | PCIE_EDMA[13]    | 0x0244           |             |
| 146              | PCIE_EDMA[14]    | 0x0248           |             |
| 147              | PCIE_EDMA[15]    | 0x024C           |             |
| 148              | GPU_EVENT        | 0x0250           |             |
| 149              | GPU_JOB          | 0x0254           |             |
| 150              | GPU_MMU          | 0x0258           |             |
| 151              | GPU              | 0x025C           |             |
| 152              | VE3              | 0x0260           |             |
| 153              | MEMC_DFS         | 0x0264           |             |
| 154              | CSI_DMA0         | 0x0268           |             |
| 155              | CSI_DMA1         | 0x026C           |             |
| 156              | CSI_DMA2         | 0x0270           |             |
| 157              | CSI_DMA3         | 0x0274           |             |
| 158              | CSI_VIPP0        | 0x0278           |             |
| 159              | CSI_VIPP1        | 0x027C           |             |
| 160              | CSI_VIPP2        | 0x0280           |             |
| 161              | CSI_VIPP3        | 0x0284           |             |
| 162              | CSI_PARSER0      | 0x0288           |             |
| 163              | CSI_PARSER1      | 0x028C           |             |
| 164              | CSI_PARSER2      | 0x0290           |             |
| 165              | CSI_ISP0         | 0x0294           |             |
| 166              | CSI_ISP1         | 0x0298           |             |
| 167              | CSI_ISP2         | 0x029C           |             |
| 168              | CSI_ISP3         | 0x02A0           |             |
| 169              | CSI_CMB          | 0x02A4           |             |
| 170              | CSI_TDM          | 0x02A8           |             |
| 171              | CSI_TOP_PKT      | 0x02AC           |             |
| 172              | GPIOK_NS         | 0x02B0           |             |
| 173              | GPIOK_S          | 0x02B4           |             |
| 174              | PWMCTRL1         | 0x02B8           |             |
| 175              | G2D              | 0x02BC           |             |
| 176              | EDP              | 0x02C0           |             |
| 177              |                  | 0x02C4           |             |
| 178              |                  | 0x02C8           |             |
| 179              | CSI_PARSER3      | 0x02CC           |             |
| 180              | NMI              | 0x02D0           |             |

| Interrupt Number | Interrupt Source         | Interrupt Vector | Description |
|------------------|--------------------------|------------------|-------------|
| 181              | S_PPU                    | 0x02D4           |             |
| 182              | S_PPU1                   | 0x02D8           |             |
| 183              | TWD                      | 0x02DC           |             |
| 184              | CPUS_WDT                 | 0x02E0           |             |
| 185              | CPUS_TIMER0              | 0x02E4           |             |
| 186              | CPUS_TIMER1              | 0x02E8           |             |
| 187              | CPUS_TIMER2              | 0x02EC           |             |
| 188              | S_TWI2                   | 0x02F0           |             |
| 189              | ALARM                    | 0x02F4           |             |
| 190              | GPIO_L_S                 | 0x02F8           |             |
| 191              | GPIO_L_NS                | 0x02FC           |             |
| 192              | GPIO_M_S                 | 0x0300           |             |
| 193              | GPIO_M_NS                | 0x0304           |             |
| 194              | S_UART0                  | 0x0308           |             |
| 195              | S_UART1                  | 0x030C           |             |
| 196              | S_TWI0                   | 0x0310           |             |
| 197              | S_TWI1                   | 0x0314           |             |
| 198              |                          | 0x0318           |             |
| 199              | S_CIRRX                  | 0x031C           |             |
| 200              | S_PWMCTRL                | 0x0320           |             |
| 201              |                          | 0x0324           |             |
| 202              | AHBS_HREADY_TI<br>ME_OUT | 0x0328           |             |
| 203              | CPUIDLE(PCK600<br>_CPU)  | 0x032C           |             |
| 204              | S_SPI                    | 0x0330           |             |
| 205              | S_SPINLOCK               | 0x0334           |             |
| 206              | CPUS_MSGBOX_C<br>PUX     | 0x0338           |             |
| 207              |                          | 0x033C           |             |
| 208              |                          | 0x0340           |             |
| 209              |                          | 0x0344           |             |
| 210              |                          | 0x0348           |             |
| 211              |                          | 0x034C           |             |
| 212              | S_TWD                    | 0x0350           |             |
| 213              |                          | 0x0354           |             |
| 214              |                          | 0x0358           |             |
| 215              |                          | 0x035C           |             |
| 216              |                          | 0x0360           |             |
| 217              | MCU_TIMER0               | 0x0364           |             |
| 218              | MCU_TIMER1               | 0x0368           |             |
| 219              | MCU_TIMER2               | 0x036C           |             |

| Interrupt Number    | Interrupt Source | Interrupt Vector | Description                                                             |
|---------------------|------------------|------------------|-------------------------------------------------------------------------|
| 220                 | MCU_AHB0_TO      | 0x0370           |                                                                         |
| 221                 | MCU_AHB1_TO      | 0x0374           |                                                                         |
| 222                 | AUDIO CODEC      | 0x0378           |                                                                         |
| 223                 | DMIC             | 0x037C           |                                                                         |
| 224                 | I2S0             | 0x0380           |                                                                         |
| 225                 | I2S1D            | 0x0384           |                                                                         |
| 226                 | I2S2             | 0x0388           |                                                                         |
| 227                 | I2S3             | 0x038C           |                                                                         |
| 228                 | OWA              | 0x0390           |                                                                         |
| 229                 | MCU_DMAC_NS      | 0x0394           |                                                                         |
| 230                 | MCU_DMAC_S       | 0x0398           |                                                                         |
| 231                 |                  | 0x039C           |                                                                         |
| 232                 |                  | 0x03A0           |                                                                         |
| 233                 | MCU_TIMER3       | 0x03A4           |                                                                         |
| 234                 | MCU_TIMER4       | 0x03A8           |                                                                         |
| 235                 | MCU_TIMER5       | 0x03AC           |                                                                         |
| 236                 |                  | 0x03B0           |                                                                         |
| 237                 |                  | 0x03B4           |                                                                         |
| 238                 | RISCV_WDT        | 0x03B8           |                                                                         |
| 239                 | MCU_PWMCTRL      | 0x03BC           |                                                                         |
| 240                 |                  | 0x03C0           |                                                                         |
| 241                 |                  | 0x03C4           |                                                                         |
| 242                 |                  | 0x03C8           |                                                                         |
| 243                 |                  | 0x03CC           |                                                                         |
| 244                 |                  | 0x03D0           |                                                                         |
| 245                 |                  | 0x03D4           |                                                                         |
| 246                 |                  | 0x03D8           |                                                                         |
| 247                 |                  | 0x03DC           |                                                                         |
| 248                 |                  | 0x03E0           |                                                                         |
| 249                 |                  | 0x03E4           |                                                                         |
| 250                 |                  | 0x03E8           |                                                                         |
| 251                 |                  | 0x03EC           |                                                                         |
| 252                 |                  | 0x03F0           |                                                                         |
| 253                 |                  | 0x03F4           |                                                                         |
| 254                 |                  | 0x03F8           |                                                                         |
| 255                 |                  | 0x03FC           |                                                                         |
| <b>CPUX Related</b> |                  |                  |                                                                         |
| 256                 | nERRIRQ[0]       | 0x0400           | L3 ECC error that causes potential data corruption or loss of coherency |
| 257                 | nERRIRQ[1]       | 0x0404           | Core0 ECC error that causes potential data                              |

| Interrupt Number | Interrupt Source | Interrupt Vector | Description                                                                |
|------------------|------------------|------------------|----------------------------------------------------------------------------|
|                  |                  |                  | corruption or loss of coherency                                            |
| 258              | nERRIRQ[2]       | 0x0408           | Core1 ECC error that causes potential data corruption or loss of coherency |
| 259              | nERRIRQ[3]       | 0x040C           | Core2 ECC error that causes potential data corruption or loss of coherency |
| 260              | nERRIRQ[4]       | 0x0410           | Core3 ECC error that causes potential data corruption or loss of coherency |
| 261              | nERRIRQ[5]       | 0x0414           | Core4 ECC error that causes potential data corruption or loss of coherency |
| 262              | nERRIRQ[6]       | 0x0418           | Core5 ECC error that causes potential data corruption or loss of coherency |
| 263              | nERRIRQ[7]       | 0x041C           | Core6 ECC error that causes potential data corruption or loss of coherency |
| 264              | nERRIRQ[8]       | 0x0220           | Core7 ECC error that causes potential data corruption or loss of coherency |
| 265              | nFAULTIRQ[0]     | 0x0424           | L3 detected 1-bit or 2-bit ECC or Parity error in the RAMs                 |
| 266              | nFAULTIRQ[1]     | 0x0428           | Core0 detected 1-bit or 2-bit ECC or Parity error in the RAMs              |
| 267              | nFAULTIRQ[2]     | 0x042C           | Core1 detected 1-bit or 2-bit ECC or Parity error in the RAMs              |
| 268              | nFAULTIRQ[3]     | 0x0430           | Core2 detected 1-bit or 2-bit ECC or Parity error in the RAMs              |

| Interrupt Number | Interrupt Source | Interrupt Vector | Description                                                   |
|------------------|------------------|------------------|---------------------------------------------------------------|
| 269              | nFAULTIRQ[4]     | 0x0434           | Core3 detected 1-bit or 2-bit ECC or Parity error in the RAMs |
| 270              | nFAULTIRQ[5]     | 0x0438           | Core4 detected 1-bit or 2-bit ECC or Parity error in the RAMs |
| 271              | nFAULTIRQ[6]     | 0x043C           | Core5 detected 1-bit or 2-bit ECC or Parity error in the RAMs |
| 272              | nFAULTIRQ[7]     | 0x0440           | Core6 detected 1-bit or 2-bit ECC or Parity error in the RAMs |
| 273              | nFAULTIRQ[8]     | 0x0444           | Core7 detected 1-bit or 2-bit ECC or Parity error in the RAMs |
| 274              | nCLUSTERPMUIRQ   | 0x0448           | Cluster PMU interrupt request                                 |
| 275              | GIC_FAULT_INT    | 0x044C           |                                                               |
| 276              | GIC_ERR_INT      | 0x0450           |                                                               |
| 277              | GIC_PMU_INT      | 0x0454           |                                                               |
| 278              |                  | 0x0458           |                                                               |
| 279              |                  | 0x045C           |                                                               |
| 280              |                  | 0x0460           |                                                               |
| 281              |                  | 0x0464           |                                                               |
| 282              |                  | 0x0468           |                                                               |
| 283              |                  | 0x046C           |                                                               |
| 284              |                  | 0x0470           |                                                               |
| 285              |                  | 0x0474           |                                                               |
| 286              |                  | 0x0478           |                                                               |
| 287              |                  | 0x047C           |                                                               |

### 2.7.3 Register List

| Module Name     | Base Address | Comments                              |
|-----------------|--------------|---------------------------------------|
| <b>GIC</b>      |              |                                       |
| GIC600_MON_4    | 0x03400000   | General interrupt controller(23*64KB) |
| GITS_TRANSLATER | 0x03450000   |                                       |



## NOTE

Offsets that are not shown are reserved and RAZ/WI. Accessing these offsets might be reported in error record 0 as a SYN\_ACE\_BAD access.

| Register Name    | Offset                        | Description                                     |
|------------------|-------------------------------|-------------------------------------------------|
| GICD_CTLR        | 0x00000                       | Distributor Control Register                    |
| GICD_TYPER       | 0x00004                       | Interrupt Controller Type Register              |
| GICD_IIDR        | 0x00008                       | Distributor Implementer Identification Register |
| GICD_FCTLR       | 0x00020                       | Function Control Register                       |
| GICD_SAC         | 0x00024                       | Secure Access Control                           |
| GICD_SETSPI_NSR  | 0x00040                       | Non-secure SPI Set Register                     |
| GICD_CLRSPI_NSR  | 0x00048                       | Non-secure SPI Clear Register                   |
| GICD_CLRSPI_NSRR | 0x00050                       | Secure SPI Set Register                         |
| GICD_CLRSPI_SR   | 0x00058                       | Secure SPI Clear Register                       |
| GICD_IGROUPRn    | 0x4*N +0x00080<br>(N=0-31)    | Interrupt Group Registers                       |
| GICD_ISENABLERn  | 0x4*N +0x00100<br>(N=0-31)    | Interrupt Set-Enable Registers 0-N              |
| GICD_ICENABLERn  | 0x4*N +0x00180<br>(N=0-31)    | Interrupt Clear-Enable Registers 0-N            |
| GICD_ISPENDRn    | 0x4*N +0x00200<br>(N=0-31)    | Interrupt Set-Pending Registers                 |
| GICD_ICPENDRn    | 0x4*N +0x00280<br>(N=0-31)    | Interrupt Clear-Pending Registers               |
| GICD_ISACTIVERn  | 0x4*N +0x00300<br>(N=0-31)    | Interrupt Set-Active Registers                  |
| GICD_ICACTIVERn  | 0x4*N +0x00380<br>(N=0-31)    | Interrupt Clear-Active Registers                |
| GICD_IPRIORITYRn | 0x4*N +0x00400<br>(N=0-255)   | Interrupt Priority Registers                    |
| GICD_ICFGRn      | 0x4*N +0x00C00<br>(N=0-63)    | Interrupt Configuration Registers               |
| GICD_IGRPMODRn   | 0x4*N +0x00D00<br>(N=0-63)    | Interrupt Group Modifier Registers              |
| GICD_NSACRn      | 0x4*N +0x00E00<br>(N=0-63)    | Non-secure Access Control Registers             |
| GICD_IROUTERn    | 0x8*N +0x06000<br>(N=32-1019) | Interrupt Routing Registers                     |
| GICD_CHIPSR      | 0x0C000                       | Chip Status Register                            |
| GICD_DCHIPR      | 0x0C004                       | Default Chip Register                           |
| GICD_CHIPRn      | 0x4*N +0x0C000                | Chip Registers                                  |

| Register Name     | Offset                     | Description                            |
|-------------------|----------------------------|----------------------------------------|
|                   | (N=2-32)                   |                                        |
| GICD_ICLARn       | 0x4*N +0xE000<br>(N=2-63)  | Interrupt Class Registers              |
| GICD_IERRRn       | 0x4*N +0xE100<br>(N=2-31)  | Interrupt Error Registers              |
| GICD_CFGID        | 0x0F000                    | Configuration ID Register              |
| GICD_PIDR4        | 0x0FFD0                    | Peripheral ID4 Register                |
| GICD_PIDR5        | 0x0FFD4                    | Peripheral ID5 Register                |
| GICD_PIDR6        | 0x0FFD8                    | Peripheral ID6 Register                |
| GICD_PIDR7        | 0x0FFDC                    | Peripheral ID7 Register                |
| GICD_PIDR0        | 0x0FFE0                    | Peripheral ID0 Register                |
| GICD_PIDR1        | 0x0FFE4                    | Peripheral ID1 Register                |
| GICD_PIDR2        | 0x0FFE8                    | Peripheral ID2 Register                |
| GICD_PIDR3        | 0x0FFEC                    | Peripheral ID3 Register                |
| GICD_CIDR0        | 0x0FFF0                    | Component ID 0 Register                |
| GICD_CIDR1        | 0x0FFF4                    | Component ID 1 Register                |
| GICD_CIDR2        | 0x0FFF8                    | Component ID 2 Register                |
| GICD_CIDR3        | 0x0FFFC                    | Component ID 3 Register                |
| GICA_SETSPI_NSR   | 0x10040                    | Aliased Non-secure SPI Set Register    |
| GICA_CLRSPN_NSR   | 0x10048                    | Aliased Non-secure SPI Clear Register  |
| GICA_SETSPI_SR    | 0x10050                    | Aliased Secure SPI Set Register        |
| GICA_CLRSPN_SR    | 0x10058                    | Aliased Secure SPI Clear Register      |
| GICT_ERR<n>FR     | 0x10*N +0x20000<br>(N=0-2) | Error Record Feature Register          |
| GICT_ERR<n>CTLR   | 0x10*N +0x20008<br>(N=0-2) | Error Record Control Register,         |
| GICT_ERR<n>STATUS | 0x10*N +0x20010<br>(N=0-2) | Error Record Primary Status Register   |
| GICT_ERR<n>ADDR   | 0x10*N +0x20018<br>(N=0-2) | Error Record Address Register          |
| GICT_ERR<n>MISC0  | 0x10*N +0x20020<br>(N=0-2) | Error Record Miscellaneous Register 0  |
| GICT_ERR<n>MISC1  | 0x10*N +0x20028<br>(N=0-2) | Error Record Miscellaneous Register 1  |
| GICT_ERRGSR       | 0x2E000                    | Error Group Status Register,           |
| GICT_ERRIRQCR<n>  | 0x4*N +0x2E800<br>(N=0-2)  | Error Interrupt Configuration Register |
| GICT_DEVARCH      | 0x2FFBC                    | Device Architecture register           |
| GICT_ERRIDR       | 0x2FFC8                    | Error Record ID Register               |
| GICT_PIDR4        | 0x2FFD0                    | Peripheral ID4 Register                |
| GICT_PIDR5        | 0x2FFD4                    | Peripheral ID5 Register                |

| Register Name     | Offset                    | Description                                     |
|-------------------|---------------------------|-------------------------------------------------|
| GICT_PIDR6        | 0x2FFD8                   | Peripheral ID6 Register                         |
| GICT_PIDR7        | 0x2FFDC                   | Peripheral ID7 Register                         |
| GICT_PIDR0        | 0x2FFE0                   | Peripheral ID0 Register                         |
| GICT_PIDR1        | 0x2FFE4                   | Peripheral ID1 Register                         |
| GICT_PIDR2        | 0x2FFE8                   | Peripheral ID2 Register                         |
| GICT_PIDR3        | 0x2FFEC                   | Peripheral ID3 Register                         |
| GICT_CIDR0        | 0x2FFF0                   | Component ID 0 Register                         |
| GICT_CIDR1        | 0x2FFF4                   | Component ID 1 Register                         |
| GICT_CIDR2        | 0x2FFF8                   | Component ID 2 Register                         |
| GICT_CIDR3        | 0x2FFFC                   | Component ID 3 Register                         |
| GICP_EVCNTRn      | 0x4*N +0x30000<br>(N=0-2) | Event Counter Registers                         |
| GICP_EVTYPERn     | 0x4*N +0x30400<br>(N=0-2) | Event Type Configuration Register               |
| GICP_SVRn         | 0x4*N +0x30600<br>(N=0-2) | Shadow Value Registers                          |
| GICP_FRn          | 0x4*N +0x30A00<br>(N=0-2) | Filter Registers                                |
| GICP_CNTENSET0    | 0x30C00                   | Counter Enable Set Register                     |
| GICP_CNTENCLR0    | 0x30C20                   | Counter Enable Clear Register 0,                |
| GICP_INTENSET0    | 0x30C40                   | Interrupt Contribution Enable Set Register 0    |
| GICP_INTENCLR0    | 0x30C60                   | Interrupt Contribution Enable Clear Register 0, |
| GICP_OVSCLR0      | 0x30C80                   | Overflow Status Clear Register 0,               |
| GICP_OVSSET0      | 0x30CC0                   | Overflow Status Set Register 0,                 |
| GICP_CAPR         | 0x30D88                   | Counter Shadow Value Capture Register           |
| GICP_CFGR         | 0x30E00                   | Configuration Information Register              |
| GICP_CR           | 0x30E04                   | Control Register                                |
| GICP_IRQCR        | 0x30E50                   | Interrupt Configuration Register                |
| GICP_PMAUTHSTATUS | 0x30FB8                   |                                                 |
| GICP_PMDEVARCH    | 0x30FBC                   |                                                 |
| GICP_PMDEVTYPE    | 0x30FCC                   |                                                 |
| GICP_PIDR4        | 0x30FD0                   | Peripheral ID4 Register                         |
| GICP_PIDR5        | 0x30FD4                   | Peripheral ID5 Register                         |
| GICP_PIDR6        | 0x30FD8                   | Peripheral ID6 Register                         |
| GICP_PIDR7        | 0x30FDC                   | Peripheral ID7 Register                         |
| GICP_PIDR0        | 0x30FE0                   | Peripheral ID0 Register                         |
| GICP_PIDR1        | 0x30FE4                   | Peripheral ID1 Register                         |
| GICP_PIDR2        | 0x30FE8                   | Peripheral ID2 Register                         |
| GICP_PIDR3        | 0x30FEC                   | Peripheral ID3 Register                         |
| GICP_CIDR0        | 0x30FF0                   | Component ID 0 Register                         |
| GICP_CIDR1        | 0x30FF4                   | Component ID 1 Register                         |
| GICP_CIDR2        | 0x30FF8                   | Component ID 2 Register                         |

| Register Name     | Offset  | Description                                           |
|-------------------|---------|-------------------------------------------------------|
| GICP_CIDR3        | 0x30FFC | Component ID 3 Register                               |
| GITS_CTLR         | 0x40000 | ITS Control Register                                  |
| GITS_IIDR         | 0x40004 | ITS Implementer Identification Register               |
| GITS_TYPER        | 0x40008 | Interrupt Controller Type Register                    |
| GITS_FCTLR        | 0x40020 | Function Control Register                             |
| GITS_OPR          | 0x40028 | Operations Register                                   |
| GITS_OPSR         | 0x40030 | Operation Status Register                             |
| GITS_CBASER       | 0x40080 | Command Queue Control Register                        |
| GITS_CWRITER      | 0x40088 | Command Queue Write Pointer Register                  |
| GITS_CREADR       | 0x40090 | Command Queue Read Pointer Register                   |
| GITS_BASER0       | 0x40100 | ITS Translation Table Descriptor Register0            |
| GITS_BASER1       | 0x40108 | ITS Translation Table Descriptor Register1            |
| GITS_CFGID        | 0x4F000 | Configuration ID Register                             |
| GITS_PIDR4        | 0x4FFD0 | Peripheral ID4 Register                               |
| GITS_PIDR5        | 0x4FFD4 | Peripheral ID5 Register                               |
| GITS_PIDR6        | 0x4FFD8 | Peripheral ID6 Register                               |
| GITS_PIDR7        | 0x4FFDC | Peripheral ID7 Register                               |
| GITS_PIDR0        | 0x4FFE0 | Peripheral ID0 Register                               |
| GITS_PIDR1        | 0x4FFE4 | Peripheral ID1 Register                               |
| GITS_PIDR2        | 0x4FFE8 | Peripheral ID2 Register                               |
| GITS_PIDR3        | 0x4FFEC | Peripheral ID3 Register                               |
| GITS_CIDR0        | 0x4FFF0 | Component ID 0 Register                               |
| GITS_CIDR1        | 0x4FFF4 | Component ID 1 Register                               |
| GITS_CIDR2        | 0x4FFF8 | Component ID 2 Register                               |
| GITS_CIDR3        | 0x4FFFC | Component ID 3 Register                               |
| GITS_TRANSLATER   | 0x50040 | ITS Translation Register                              |
| GICR_CTLR_C0      | 0x60000 | Redistributor Control Register                        |
| GICR_IIDR_C0      | 0x60004 | Redistributor Implementation Identification Register  |
| GICR_TYPER_C0     | 0x60008 | Interrupt Controller Type Register                    |
| GICR_WAKER_C0     | 0x60014 | Power Management Control Register                     |
| GICR_FCTLR_C0     | 0x60020 | Function Control Register                             |
| GICR_PWRR_C0      | 0x60024 | Power Register                                        |
| GICR_CLASS_C0     | 0x60028 | Class Register                                        |
| GICR_SETLPIR_C0   | 0x60040 |                                                       |
| GICR_CLRLPIR_C0   | 0x60048 |                                                       |
| GICR_PROPBASER_C0 | 0x60070 | Redistributor Properties Base Address Register        |
| GICR_PENDBASER_C0 | 0x60078 | Redistributor LPI Pending Table Base Address Register |
| GICR_INVLPIR_C0   | 0x600A0 |                                                       |
| GICR_INVALLR_C0   | 0x600B0 |                                                       |
| GICR_SYNCR_C0     | 0x600C0 |                                                       |

| Register Name       | Offset                    | Description                                          |
|---------------------|---------------------------|------------------------------------------------------|
| GICR_PIDR4_C0       | 0x6FFD0                   | Peripheral ID4 Register                              |
| GICR_PIDR5_C0       | 0x6FFD4                   | Peripheral ID5 Register                              |
| GICR_PIDR6_C0       | 0x6FFD8                   | Peripheral ID6 Register                              |
| GICR_PIDR7_C0       | 0x6FFDC                   | Peripheral ID7 Register                              |
| GICR_PIDR0_C0       | 0x6FFE0                   | Peripheral ID0 Register                              |
| GICR_PIDR1_C0       | 0x6FFE4                   | Peripheral ID1 Register                              |
| GICR_PIDR2_C0       | 0x6FFE8                   | Peripheral ID2 Register                              |
| GICR_PIDR3_C0       | 0x6FFEC                   | Peripheral ID3 Register                              |
| GICR_CIDR0_C0       | 0x6FFF0                   | Component ID 0 Register                              |
| GICR_CIDR1_C0       | 0x6FFF4                   | Component ID 1 Register                              |
| GICR_CIDR2_C0       | 0x6FFF8                   | Component ID 2 Register                              |
| GICR_CIDR3_C0       | 0x6FFFC                   | Component ID 3 Register                              |
| GICR_IGROUPR0_C0    | 0x70080                   | Interrupt Group Register                             |
| GICR_ISENABLER0_C0  | 0x70100                   | Interrupt Set-Enable Register                        |
| GICR_ICENABLER0_C0  | 0x70180                   | Interrupt Clear-Enable Register                      |
| GICR_ISPENDR0_C0    | 0x70200                   | Interrupt Set-Pending Register                       |
| GICR_ICPENDR0_C0    | 0x70280                   | Peripheral Clear Pending Register                    |
| GICR_ISACTIVER0_C0  | 0x70300                   | Interrupt Set-Active Register                        |
| GICR_ICACTIVER0_C0  | 0x70380                   | Interrupt Clear-Active Register                      |
| GICR_IPRIORITYRn_C0 | 0x4*N +0x70400<br>(N=0-7) | Interrupt Priority Registers                         |
| GICR_ICFGRn_C0      | 0x4*N +0x70C00<br>(N=0-1) | Interrupt Configuration Registers                    |
| GICR_IGRPMODR0_C0   | 0x70D00                   | Interrupt Group Modifier Register                    |
| GICR_NSACR_C0       | 0x70E00                   | Non-secure Access Control Register                   |
| GICR_MISCSTATUSR_C0 | 0x7C000                   | Miscellaneous Status Register                        |
| GICR_IERRVR_C0      | 0x7C008                   | Interrupt Error Valid Register                       |
| GICR_SGIDR_C0       | 0x7C010                   | SGI Default Register                                 |
| GICR_CFGID0_C0      | 0x7F000                   | Configuration ID0 Register                           |
| GICR_CFGID1_C0      | 0x7F004                   | Configuration ID1 Register                           |
| GICR_CTLR_C1        | 0x80000                   | Redistributor Control Register                       |
| GICR_IIDR_C1        | 0x80004                   | Redistributor Implementation Identification Register |
| GICR_TYPER_C1       | 0x80008                   | Interrupt Controller Type Register                   |
| GICR_WAKER_C1       | 0x80014                   | Power Management Control Register                    |
| GICR_FCTLR_C1       | 0x80020                   | Function Control Register                            |
| GICR_PWRR_C1        | 0x80024                   | Power Register                                       |
| GICR_CLASS_C1       | 0x80028                   | Class Register                                       |
| GICR_SETLPIR_C1     | 0x80040                   |                                                      |
| GICR_CLRLPIR_C1     | 0x80048                   |                                                      |
| GICR_PROPBASER_C1   | 0x80070                   | Redistributor Properties Base Address Register       |
| GICR_PENDBASER_C1   | 0x80078                   | Redistributor LPI Pending Table Base Address         |

| Register Name       | Offset                    | Description                                          |
|---------------------|---------------------------|------------------------------------------------------|
|                     |                           | Register                                             |
| GICR_INVLPIR_C1     | 0x800A0                   |                                                      |
| GICR_INVALLR_C1     | 0x800B0                   |                                                      |
| GICR_SYNCR_C1       | 0x800C0                   |                                                      |
| GICR_PIDR4_C1       | 0x8FFD0                   | Peripheral ID4 Register                              |
| GICR_PIDR5_C1       | 0x8FFD4                   | Peripheral ID5 Register                              |
| GICR_PIDR6_C1       | 0x8FFD8                   | Peripheral ID6 Register                              |
| GICR_PIDR7_C1       | 0x8FFDC                   | Peripheral ID7 Register                              |
| GICR_PIDR0_C1       | 0x8FFE0                   | Peripheral ID0 Register                              |
| GICR_PIDR1_C1       | 0x8FFE4                   | Peripheral ID1 Register                              |
| GICR_PIDR2_C1       | 0x8FFE8                   | Peripheral ID2 Register                              |
| GICR_PIDR3_C1       | 0x8FFEC                   | Peripheral ID3 Register                              |
| GICR_CIDR0_C1       | 0x8FFF0                   | Component ID 0 Register                              |
| GICR_CIDR1_C1       | 0x8FFF4                   | Component ID 1 Register                              |
| GICR_CIDR2_C1       | 0x8FFF8                   | Component ID 2 Register                              |
| GICR_CIDR3_C1       | 0x8FFFC                   | Component ID 3 Register                              |
| GICR_IGROUPR0_C1    | 0x90080                   | Interrupt Group Register                             |
| GICR_ISENABLER0_C1  | 0x90100                   | Interrupt Set-Enable Register                        |
| GICR_ICENABLER0_C1  | 0x90180                   | Interrupt Clear-Enable Register                      |
| GICR_ISPENDR0_C1    | 0x90200                   | Interrupt Set-Pending Register                       |
| GICR_ICPENDR0_C1    | 0x90280                   | Peripheral Clear Pending Register                    |
| GICR_ISACTIVER0_C1  | 0x90300                   | Interrupt Set-Active Register                        |
| GICR_ICACTIVER0_C1  | 0x90380                   | Interrupt Clear-Active Register                      |
| GICR_IPRIORITYRn_C1 | 0x4*N +0x90400<br>(N=0-7) | Interrupt Priority Registers                         |
| GICR_ICFGRn_C1      | 0x4*N +0x90C00<br>(N=0-1) | Interrupt Configuration Registers                    |
| GICR_IGRPMODR0_C1   | 0x90D00                   | Interrupt Group Modifier Register                    |
| GICR_NSACR_C1       | 0x90E00                   | Non-secure Access Control Register                   |
| GICR_MISCSTATUSR_C1 | 0x9C000                   | Miscellaneous Status Register                        |
| GICR_IERRVR_C1      | 0x9C008                   | Interrupt Error Valid Register                       |
| GICR_SGIDR_C1       | 0x9C010                   | SGI Default Register                                 |
| GICR_CFGID0_C1      | 0x9F000                   | Configuration ID0 Register                           |
| GICR_CFGID1_C1      | 0x9F004                   | Configuration ID1 Register                           |
| GICR_CTLR_C2        | 0xA0000                   | Redistributor Control Register                       |
| GICR_IIDR_C2        | 0xA0004                   | Redistributor Implementation Identification Register |
| GICR_TYPER_C2       | 0xA0008                   | Interrupt Controller Type Register                   |
| GICR_WAKER_C2       | 0xA0014                   | Power Management Control Register                    |
| GICR_FCTLR_C2       | 0xA0020                   | Function Control Register                            |
| GICR_PWRR_C2        | 0xA0024                   | Power Register                                       |
| GICR_CLASS_C2       | 0xA0028                   | Class Register                                       |

| Register Name       | Offset                    | Description                                           |
|---------------------|---------------------------|-------------------------------------------------------|
| GICR_SETLPIR_C2     | 0xA0040                   |                                                       |
| GICR_CLRLPIR_C2     | 0xA0048                   |                                                       |
| GICR_PROPBASER_C2   | 0xA0070                   | Redistributor Properties Base Address Register        |
| GICR_PENDBASER_C2   | 0xA0078                   | Redistributor LPI Pending Table Base Address Register |
| GICR_INVLPIR_C2     | 0xA00A0                   |                                                       |
| GICR_INVALLR_C2     | 0xA00B0                   |                                                       |
| GICR_SYNCR_C2       | 0xA00C0                   |                                                       |
| GICR_PIDR4_C2       | 0xAFD0                    | Peripheral ID4 Register                               |
| GICR_PIDR5_C2       | 0xAFD4                    | Peripheral ID5 Register                               |
| GICR_PIDR6_C2       | 0xAFD8                    | Peripheral ID6 Register                               |
| GICR_PIDR7_C2       | 0xAFDC                    | Peripheral ID7 Register                               |
| GICR_PIDR0_C2       | 0xAFE0                    | Peripheral ID0 Register                               |
| GICR_PIDR1_C2       | 0xAFE4                    | Peripheral ID1 Register                               |
| GICR_PIDR2_C2       | 0xAFE8                    | Peripheral ID2 Register                               |
| GICR_PIDR3_C2       | 0xAFEC                    | Peripheral ID3 Register                               |
| GICR_CIDR0_C2       | 0xAFF0                    | Component ID 0 Register                               |
| GICR_CIDR1_C2       | 0xAFF4                    | Component ID 1 Register                               |
| GICR_CIDR2_C2       | 0xAFF8                    | Component ID 2 Register                               |
| GICR_CIDR3_C2       | 0xAFFC                    | Component ID 3 Register                               |
| GICR_IGROUPR0_C2    | 0xB0080                   | Interrupt Group Register                              |
| GICR_ISENABLER0_C2  | 0xB0100                   | Interrupt Set-Enable Register                         |
| GICR_ICENABLER0_C2  | 0xB0180                   | Interrupt Clear-Enable Register                       |
| GICR_ISPENDR0_C2    | 0xB0200                   | Interrupt Set-Pending Register                        |
| GICR_ICPENDR0_C2    | 0xB0280                   | Peripheral Clear Pending Register                     |
| GICR_ISACTIVER0_C2  | 0xB0300                   | Interrupt Set-Active Register                         |
| GICR_ICACTIVER0_C2  | 0xB0380                   | Interrupt Clear-Active Register                       |
| GICR_IPRIORITYRn_C2 | 0x4*N +0xB0400<br>(N=0-7) | Interrupt Priority Registers                          |
| GICR_ICFGRn_C2      | 0x4*N +0xB0C00<br>(N=0-1) | Interrupt Configuration Registers                     |
| GICR_IGRPMODR0_C2   | 0xB0D00                   | Interrupt Group Modifier Register                     |
| GICR_NSACR_C2       | 0xB0E00                   | Non-secure Access Control Register                    |
| GICR_MISCSTATUSR_C2 | 0xBC000                   | Miscellaneous Status Register                         |
| GICR_IERRVR_C2      | 0xBC008                   | Interrupt Error Valid Register                        |
| GICR_SGIDR_C2       | 0xBC010                   | SGI Default Register                                  |
| GICR_CFGID0_C2      | 0xBF000                   | Configuration ID0 Register                            |
| GICR_CFGID1_C2      | 0xBF004                   | Configuration ID1 Register                            |
| GICR_CTLR_C3        | 0xC0000                   | Redistributor Control Register                        |
| GICR_IIDR_C3        | 0xC0004                   | Redistributor Implementation Identification Register  |
| GICR_TYPER_C3       | 0xC0008                   | Interrupt Controller Type Register                    |

| Register Name       | Offset                    | Description                                           |
|---------------------|---------------------------|-------------------------------------------------------|
| GICR_WAKER_C3       | 0xC0014                   | Power Management Control Register                     |
| GICR_FCTLR_C3       | 0xC0020                   | Function Control Register                             |
| GICR_PWRR_C3        | 0xC0024                   | Power Register                                        |
| GICR_CLASS_C3       | 0xC0028                   | Class Register                                        |
| GICR_SETLPIR_C3     | 0xC0040                   |                                                       |
| GICR_CLRLPIR_C3     | 0xC0048                   |                                                       |
| GICR_PROPBASER_C3   | 0xC0070                   | Redistributor Properties Base Address Register        |
| GICR_PENDBASER_C3   | 0xC0078                   | Redistributor LPI Pending Table Base Address Register |
| GICR_INVLPIR_C3     | 0xC00A0                   |                                                       |
| GICR_INVALLR_C3     | 0xC00B0                   |                                                       |
| GICR_SYNCR_C3       | 0xC00C0                   |                                                       |
| GICR_PIDR4_C3       | 0xCFFD0                   | Peripheral ID4 Register                               |
| GICR_PIDR5_C3       | 0xCFFD4                   | Peripheral ID5 Register                               |
| GICR_PIDR6_C3       | 0xCFFD8                   | Peripheral ID6 Register                               |
| GICR_PIDR7_C3       | 0xCFFDC                   | Peripheral ID7 Register                               |
| GICR_PIDR0_C3       | 0xCFFE0                   | Peripheral ID0 Register                               |
| GICR_PIDR1_C3       | 0xCFFE4                   | Peripheral ID1 Register                               |
| GICR_PIDR2_C3       | 0xCFFE8                   | Peripheral ID2 Register                               |
| GICR_PIDR3_C3       | 0xCFFEC                   | Peripheral ID3 Register                               |
| GICR_CIDR0_C3       | 0xCFFF0                   | Component ID 0 Register                               |
| GICR_CIDR1_C3       | 0xCFFF4                   | Component ID 1 Register                               |
| GICR_CIDR2_C3       | 0xCFFF8                   | Component ID 2 Register                               |
| GICR_CIDR3_C3       | 0xCFFFC                   | Component ID 3 Register                               |
| GICR_IGROUPR0       | 0xD0080                   | Interrupt Group Register                              |
| GICR_ISENABLER0_C3  | 0xD0100                   | Interrupt Set-Enable Register                         |
| GICR_ICENABLER0_C3  | 0xD0180                   | Interrupt Clear-Enable Register                       |
| GICR_ISPENDR0_C3    | 0xD0200                   | Interrupt Set-Pending Register                        |
| GICR_ICPENDR0_C3    | 0xD0280                   | Peripheral Clear Pending Register                     |
| GICR_ISACTIVER0_C3  | 0xD0300                   | Interrupt Set-Active Register                         |
| GICR_ICACTIVER0_C3  | 0xD0380                   | Interrupt Clear-Active Register                       |
| GICR_IPRIORITYRn_C3 | 0x4*N +0xD0400<br>(N=0-7) | Interrupt Priority Registers                          |
| GICR_ICFGRn_C3      | 0x4*N +0xD0C00<br>(N=0-1) | Interrupt Configuration Registers                     |
| GICR_IGRPMODR0_C3   | 0xD0D00                   | Interrupt Group Modifier Register                     |
| GICR_NSACR_C3       | 0xD0E00                   | Non-secure Access Control Register                    |
| GICR_MISCSTATUSR_C3 | 0xDC000                   | Miscellaneous Status Register                         |
| GICR_IERRVR_C3      | 0xDC008                   | Interrupt Error Valid Register                        |
| GICR_SGIDR_C3       | 0xDC010                   | SGI Default Register                                  |
| GICR_CFGID0_C3      | 0xDF000                   | Configuration ID0 Register                            |
| GICR_CFGID1_C3      | 0xDF004                   | Configuration ID1 Register                            |

| Register Name       | Offset                     | Description                                           |
|---------------------|----------------------------|-------------------------------------------------------|
| GICR_CTLR_C4        | 0xE0000                    | Redistributor Control Register                        |
| GICR_IIDR_C4        | 0xE0004                    | Redistributor Implementation Identification Register  |
| GICR_TYPER_C4       | 0xE0008                    | Interrupt Controller Type Register                    |
| GICR_WAKER_C4       | 0xE0014                    | Power Management Control Register                     |
| GICR_FCTLR_C4       | 0xE0020                    | Function Control Register                             |
| GICR_PWRR_C4        | 0xE0024                    | Power Register                                        |
| GICR_CLASS_C4       | 0xE0028                    | Class Register                                        |
| GICR_SETLPIR_C4     | 0xE0040                    |                                                       |
| GICR_CLRLPIR_C4     | 0xE0048                    |                                                       |
| GICR_PROPBASER_C4   | 0xE0070                    | Redistributor Properties Base Address Register        |
| GICR_PENDBASER_C4   | 0xE0078                    | Redistributor LPI Pending Table Base Address Register |
| GICR_INVLPIR_C4     | 0xE00A0                    |                                                       |
| GICR_INVALLR_C4     | 0xE00B0                    |                                                       |
| GICR_SYNCR_C4       | 0xE00C0                    |                                                       |
| GICR_PIDR4_C4       | 0xEFFD0                    | Peripheral ID4 Register                               |
| GICR_PIDR5_C4       | 0xEFFD4                    | Peripheral ID5 Register                               |
| GICR_PIDR6_C4       | 0xEFFD8                    | Peripheral ID6 Register                               |
| GICR_PIDR7_C4       | 0xEFFDC                    | Peripheral ID7 Register                               |
| GICR_PIDR0_C4       | 0xEFFE0                    | Peripheral ID0 Register                               |
| GICR_PIDR1_C4       | 0xEFFE4                    | Peripheral ID1 Register                               |
| GICR_PIDR2_C4       | 0xEFFE8                    | Peripheral ID2 Register                               |
| GICR_PIDR3_C4       | 0xEFFEC                    | Peripheral ID3 Register                               |
| GICR_CIDR0_C4       | 0xEFFF0                    | Component ID 0 Register                               |
| GICR_CIDR1_C4       | 0xEFFF4                    | Component ID 1 Register                               |
| GICR_CIDR2_C4       | 0xEFFF8                    | Component ID 2 Register                               |
| GICR_CIDR3_C4       | 0xEFFFC                    | Component ID 3 Register                               |
| GICR_IGROUPR0       | 0xF0080                    | Interrupt Group Register                              |
| GICR_ISENABLER0_C4  | 0xF0100                    | Interrupt Set-Enable Register                         |
| GICR_ICENABLER0_C4  | 0xF0180                    | Interrupt Clear-Enable Register                       |
| GICR_ISPENDR0_C4    | 0xF0200                    | Interrupt Set-Pending Register                        |
| GICR_ICPENDR0_C4    | 0xF0280                    | Peripheral Clear Pending Register                     |
| GICR_ISACTIVER0_C4  | 0xF0300                    | Interrupt Set-Active Register                         |
| GICR_ICACTIVER0_C4  | 0xF0380                    | Interrupt Clear-Active Register                       |
| GICR_IPRIORITYRn_C4 | 0x4*N + 0xF0400<br>(N=0-7) | Interrupt Priority Registers                          |
| GICR_ICFGRn_C4      | 0x4*N + 0xF0C00<br>(N=0-1) | Interrupt Configuration Registers                     |
| GICR_IGRPMODR0_C4   | 0xF0D00                    | Interrupt Group Modifier Register                     |
| GICR_NSACR_C4       | 0xF0E00                    | Non-secure Access Control Register                    |
| GICR_MISCSTATUSR_C4 | 0xFC000                    | Miscellaneous Status Register                         |

| Register Name       | Offset                     | Description                                           |
|---------------------|----------------------------|-------------------------------------------------------|
| GICR_IERRVR_C4      | 0xFC008                    | Interrupt Error Valid Register                        |
| GICR_SGIDR_C4       | 0xFC010                    | SGI Default Register                                  |
| GICR_CFGID0_C4      | 0xFF000                    | Configuration ID0 Register                            |
| GICR_CFGID1_C4      | 0xFF004                    | Configuration ID1 Register                            |
| GICR_CTLR_C5        | 0x100000                   | Redistributor Control Register                        |
| GICR_IIDR_C5        | 0x100004                   | Redistributor Implementation Identification Register  |
| GICR_TYPER_C5       | 0x100008                   | Interrupt Controller Type Register                    |
| GICR_WAKER_C5       | 0x100014                   | Power Management Control Register                     |
| GICR_FCTLR_C5       | 0x100020                   | Function Control Register                             |
| GICR_PWRR_C5        | 0x100024                   | Power Register                                        |
| GICR_CLASS_C5       | 0x100028                   | Class Register                                        |
| GICR_SETLPIR_C5     | 0x100040                   |                                                       |
| GICR_CLRLPIR_C5     | 0x100048                   |                                                       |
| GICR_PROPBASER_C5   | 0x100070                   | Redistributor Properties Base Address Register        |
| GICR_PENDBASER_C5   | 0x100078                   | Redistributor LPI Pending Table Base Address Register |
| GICR_INVLPIR_C5     | 0x1000A0                   |                                                       |
| GICR_INVALLR_C5     | 0x1000B0                   |                                                       |
| GICR_SYNCR_C5       | 0x1000C0                   |                                                       |
| GICR_PIDR4_C5       | 0x10FFD0                   | Peripheral ID4 Register                               |
| GICR_PIDR5_C5       | 0x10FFD4                   | Peripheral ID5 Register                               |
| GICR_PIDR6_C5       | 0x10FFD8                   | Peripheral ID6 Register                               |
| GICR_PIDR7_C5       | 0x10FFDC                   | Peripheral ID7 Register                               |
| GICR_PIDR0_C5       | 0x10FFE0                   | Peripheral ID0 Register                               |
| GICR_PIDR1_C5       | 0x10FFE4                   | Peripheral ID1 Register                               |
| GICR_PIDR2_C5       | 0x10FFE8                   | Peripheral ID2 Register                               |
| GICR_PIDR3_C5       | 0x10FFEC                   | Peripheral ID3 Register                               |
| GICR_CIDR0_C5       | 0x10FFF0                   | Component ID 0 Register                               |
| GICR_CIDR1_C5       | 0x10FFF4                   | Component ID 1 Register                               |
| GICR_CIDR2_C5       | 0x10FFF8                   | Component ID 2 Register                               |
| GICR_CIDR3_C5       | 0x10FFFC                   | Component ID 3 Register                               |
| GICR_IGROUPRO       | 0x110080                   | Interrupt Group Register                              |
| GICR_ISENABLER0_C5  | 0x110100                   | Interrupt Set-Enable Register                         |
| GICR_ICENABLER0_C5  | 0x110180                   | Interrupt Clear-Enable Register                       |
| GICR_ISPENDR0_C5    | 0x110200                   | Interrupt Set-Pending Register                        |
| GICR_ICPENDR0_C5    | 0x110280                   | Peripheral Clear Pending Register                     |
| GICR_ISACTIVER0_C5  | 0x110300                   | Interrupt Set-Active Register                         |
| GICR_ICACTIVER0_C5  | 0x110380                   | Interrupt Clear-Active Register                       |
| GICR_IPRIORITYRn_C5 | 0x4*N +0x110400<br>(N=0-7) | Interrupt Priority Registers                          |
| GICR_ICFGRn_C5      | 0x4*N +0x110C00            | Interrupt Configuration Registers                     |

| Register Name       | Offset   | Description                                           |
|---------------------|----------|-------------------------------------------------------|
|                     | (N=0-1)  |                                                       |
| GICR_IGRPMODR0_C5   | 0x110D00 | Interrupt Group Modifier Register                     |
| GICR_NSACR_C5       | 0x110E00 | Non-secure Access Control Register                    |
| GICR_MISCSTATUSR_C5 | 0x11C000 | Miscellaneous Status Register                         |
| GICR_IERRVR_C5      | 0x11C008 | Interrupt Error Valid Register                        |
| GICR_SGIDR_C5       | 0x11C010 | SGI Default Register                                  |
| GICR_CFGID0_C5      | 0x11F000 | Configuration ID0 Register                            |
| GICR_CFGID1_C5      | 0x11F004 | Configuration ID1 Register                            |
| GICR_CTLR_C6        | 0x120000 | Redistributor Control Register                        |
| GICR_IIDR_C6        | 0x120004 | Redistributor Implementation Identification Register  |
| GICR_TYPER_C6       | 0x120008 | Interrupt Controller Type Register                    |
| GICR_WAKER_C6       | 0x120014 | Power Management Control Register                     |
| GICR_FCTLR_C6       | 0x120020 | Function Control Register                             |
| GICR_PWRR_C6        | 0x120024 | Power Register                                        |
| GICR_CLASS_C6       | 0x120028 | Class Register                                        |
| GICR_SETLPIR_C6     | 0x120040 |                                                       |
| GICR_CLRLPIR_C6     | 0x120048 |                                                       |
| GICR_PROPBASER_C6   | 0x120070 | Redistributor Properties Base Address Register        |
| GICR_PENDBASER_C6   | 0x120078 | Redistributor LPI Pending Table Base Address Register |
| GICR_INVLPIR_C6     | 0x1200A0 |                                                       |
| GICR_INVALLR_C6     | 0x1200B0 |                                                       |
| GICR_SYNCR_C6       | 0x1200C0 |                                                       |
| GICR_PIDR4_C6       | 0x12FFD0 | Peripheral ID4 Register                               |
| GICR_PIDR5_C6       | 0x12FFD4 | Peripheral ID5 Register                               |
| GICR_PIDR6_C6       | 0x12FFD8 | Peripheral ID6 Register                               |
| GICR_PIDR7_C6       | 0x12FFDC | Peripheral ID7 Register                               |
| GICR_PIDR0_C6       | 0x12FFE0 | Peripheral ID0 Register                               |
| GICR_PIDR1_C6       | 0x12FFE4 | Peripheral ID1 Register                               |
| GICR_PIDR2_C6       | 0x12FFE8 | Peripheral ID2 Register                               |
| GICR_PIDR3_C6       | 0x12FFEC | Peripheral ID3 Register                               |
| GICR_CIDR0_C6       | 0x12FFF0 | Component ID 0 Register                               |
| GICR_CIDR1_C6       | 0x12FFF4 | Component ID 1 Register                               |
| GICR_CIDR2_C6       | 0x12FFF8 | Component ID 2 Register                               |
| GICR_CIDR3_C6       | 0x12FFFC | Component ID 3 Register                               |
| GICR_IGROUPR0       | 0x130080 | Interrupt Group Register                              |
| GICR_ISENABLER0_C6  | 0x130100 | Interrupt Set-Enable Register                         |
| GICR_ICENABLER0_C6  | 0x130180 | Interrupt Clear-Enable Register                       |
| GICR_ISPENDR0_C6    | 0x130200 | Interrupt Set-Pending Register                        |
| GICR_ICPENDR0_C6    | 0x130280 | Peripheral Clear Pending Register                     |
| GICR_ISACTIVER0_C6  | 0x130300 | Interrupt Set-Active Register                         |

| Register Name       | Offset                     | Description                                           |
|---------------------|----------------------------|-------------------------------------------------------|
| GICR_ICACTIVER0_C6  | 0x130380                   | Interrupt Clear-Active Register                       |
| GICR_IPRIORITYRn_C6 | 0x4*N +0x130400<br>(N=0-7) | Interrupt Priority Registers                          |
| GICR_ICFGRn_C6      | 0x4*N +0x130C00<br>(N=0-1) | Interrupt Configuration Registers                     |
| GICR_IGRPMODR0_C6   | 0x130D00                   | Interrupt Group Modifier Register                     |
| GICR_NSACR_C6       | 0x130E00                   | Non-secure Access Control Register                    |
| GICR_MISCSTATUSR_C6 | 0x13C000                   | Miscellaneous Status Register                         |
| GICR_IERRVR_C6      | 0x13C008                   | Interrupt Error Valid Register                        |
| GICR_SGIDR_C6       | 0x13C010                   | SGI Default Register                                  |
| GICR_CFGID0_C6      | 0x13F000                   | Configuration ID0 Register                            |
| GICR_CFGID1_C6      | 0x13F004                   | Configuration ID1 Register                            |
| GICR_CTLR_C7        | 0x140000                   | Redistributor Control Register                        |
| GICR_IIDR_C7        | 0x140004                   | Redistributor Implementation Identification Register  |
| GICR_TYPER_C7       | 0x140008                   | Interrupt Controller Type Register                    |
| GICR_WAKER_C7       | 0x140014                   | Power Management Control Register                     |
| GICR_FCTLR_C7       | 0x140020                   | Function Control Register                             |
| GICR_PWRR_C7        | 0x140024                   | Power Register                                        |
| GICR_CLASS_C7       | 0x140028                   | Class Register                                        |
| GICR_SETLPIR_C7     | 0x140040                   |                                                       |
| GICR_CLRLPIR_C7     | 0x140048                   |                                                       |
| GICR_PROPBASER_C7   | 0x140070                   | Redistributor Properties Base Address Register        |
| GICR_PENDBASER_C7   | 0x140078                   | Redistributor LPI Pending Table Base Address Register |
| GICR_INVLPIR_C7     | 0x1400A0                   |                                                       |
| GICR_INVALLR_C7     | 0x1400B0                   |                                                       |
| GICR_SYNCR_C7       | 0x1400C0                   |                                                       |
| GICR_PIDR4_C7       | 0x14FFD0                   | Peripheral ID4 Register                               |
| GICR_PIDR5_C7       | 0x14FFD4                   | Peripheral ID5 Register                               |
| GICR_PIDR6_C7       | 0x14FFD8                   | Peripheral ID6 Register                               |
| GICR_PIDR7_C7       | 0x14FFDC                   | Peripheral ID7 Register                               |
| GICR_PIDR0_C7       | 0x14FFE0                   | Peripheral ID0 Register                               |
| GICR_PIDR1_C7       | 0x14FFE4                   | Peripheral ID1 Register                               |
| GICR_PIDR2_C7       | 0x14FFE8                   | Peripheral ID2 Register                               |
| GICR_PIDR3_C7       | 0x14FFEC                   | Peripheral ID3 Register                               |
| GICR_CIDR0_C7       | 0x14FFF0                   | Component ID 0 Register                               |
| GICR_CIDR1_C7       | 0x14FFF4                   | Component ID 1 Register                               |
| GICR_CIDR2_C7       | 0x14FFF8                   | Component ID 2 Register                               |
| GICR_CIDR3_C7       | 0x14FFFC                   | Component ID 3 Register                               |
| GICR_IGROUPR0       | 0x150080                   | Interrupt Group Register                              |
| GICR_ISENABLER0_C7  | 0x150100                   | Interrupt Set-Enable Register                         |

| Register Name       | Offset                       | Description                                     |
|---------------------|------------------------------|-------------------------------------------------|
| GICR_ICENABLER0_C7  | 0x150180                     | Interrupt Clear-Enable Register                 |
| GICR_ISPENDR0_C7    | 0x150200                     | Interrupt Set-Pending Register                  |
| GICR_ICPENDR0_C7    | 0x150280                     | Peripheral Clear Pending Register               |
| GICR_ISACTIVER0_C7  | 0x150300                     | Interrupt Set-Active Register                   |
| GICR_ICACTIVER0_C7  | 0x150380                     | Interrupt Clear-Active Register                 |
| GICR_IPRIORITYRn_C7 | 0x4*N +0x150400<br>(N=0-7)   | Interrupt Priority Registers                    |
| GICR_ICFGRn_C7      | 0x4*N +0x150C00<br>(N=0-1)   | Interrupt Configuration Registers               |
| GICR_IGRPMODR0_C7   | 0x150D00                     | Interrupt Group Modifier Register               |
| GICR_NSACR_C7       | 0x150E00                     | Non-secure Access Control Register              |
| GICR_MISCSTATUSR_C7 | 0x15C000                     | Miscellaneous Status Register                   |
| GICR_IERRVR_C7      | 0x15C008                     | Interrupt Error Valid Register                  |
| GICR_SGIDR_C7       | 0x15C010                     | SGI Default Register                            |
| GICR_CFGID0_C7      | 0x15F000                     | Configuration ID0 Register                      |
| GICR_CFGID1_C7      | 0x15F004                     | Configuration ID1 Register                      |
| GICDA_CTRLR         | 0x160000                     | Distributor Control Register                    |
| GICDA_TYPER         | 0x160004                     | Interrupt Controller Type Register              |
| GICDA_IIDR          | 0x160008                     | Distributor Implementer Identification Register |
| GICDA_FCTRLR        | 0x160020                     | Function Control Register                       |
| GICDA_SAC           | 0x160024                     | Secure Access Control                           |
| GICDA_SETSPI_NSR    | 0x160040                     | Non-secure SPI Set Register                     |
| GICDA_CLRSPN_NSR    | 0x160048                     | Non-secure SPI Clear Register                   |
| GICDA_CLRSPI_NSR    | 0x160050                     | Secure SPI Set Register                         |
| GICDA_CLRSPI_SR     | 0x160058                     | Secure SPI Clear Register                       |
| GICDA_IGROUPRN      | 0x4*N +0x160080<br>(N=0-31)  | Interrupt Group Registers                       |
| GICDA_ISENABLERn    | 0x4*N +0x160100<br>(N=0-31)  | Interrupt Set-Enable Registers 0-N              |
| GICDA_ICENABLERn    | 0x4*N +0x160180<br>(N=0-31)  | Interrupt Clear-Enable Registers 0-N            |
| GICDA_ISPENDRn      | 0x4*N +0x160200<br>(N=0-31)  | Interrupt Set-Pending Registers                 |
| GICDA_ICPENDRn      | 0x4*N +0x160280<br>(N=0-31)  | Interrupt Clear-Pending Registers               |
| GICDA_ISACTIVERn    | 0x4*N +0x160300<br>(N=0-31)  | Interrupt Set-Active Registers                  |
| GICDA_ICACTIVERn    | 0x4*N +0x160380<br>(N=0-31)  | Interrupt Clear-Active Registers                |
| GICDA_IPRIORITYRn   | 0x4*N +0x160400<br>(N=0-255) | Interrupt Priority Registers                    |
| GICDA_ICFGRn        | 0x4*N +0x160C00              | Interrupt Configuration Registers               |

| Register Name   | Offset                             | Description                         |
|-----------------|------------------------------------|-------------------------------------|
|                 | (N=0-63)                           |                                     |
| GICDA_IGRPMODRn | 0x4*N<br>+0x160D00<br>(N=0-63)     | Interrupt Group Modifier Registers  |
| GICDA_NSACRn    | 0x4*N +0x160E00<br>(N=0-63)        | Non-secure Access Control Registers |
| GICDA_IROUTERn  | 0x16*N<br>+0x166000<br>(N=32-1019) | Interrupt Routing Registers         |
| GICDA_CHIPSR    | 0x16C000                           | Chip Status Register                |
| GICDA_DCHIPR    | 0x16C004                           | Default Chip Register               |
| GICDA_CHIPRn    | 0x4*N +0x16C000<br>(N=2-32)        | Chip Registers                      |
| GICDA_ICLARn    | 0x4*N +0x16E000<br>(N=2-63)        | Interrupt Class Registers           |
| GICDA_IERRRn    | 0x4*N +0x16E100<br>(N=2-31)        | Interrupt Error Registers           |
| GICDA_CFGID     | 0x16F000                           | Configuration ID Register           |
| GICDA_PIDR4     | 0x16FFD0                           | Peripheral ID4 Register             |
| GICDA_PIDR5     | 0x16FFD4                           | Peripheral ID5 Register             |
| GICDA_PIDR6     | 0x16FFD8                           | Peripheral ID6 Register             |
| GICDA_PIDR7     | 0x16FFDC                           | Peripheral ID7 Register             |
| GICDA_PIDR0     | 0x16FFE0                           | Peripheral ID0 Register             |
| GICDA_PIDR1     | 0x16FFE4                           | Peripheral ID1 Register             |
| GICDA_PIDR2     | 0x16FFE8                           | Peripheral ID2 Register             |
| GICDA_PIDR3     | 0x16FFEC                           | Peripheral ID3 Register             |
| GICDA_CIDR0     | 0x16FFF0                           | Component ID 0 Register             |
| GICDA_CIDR1     | 0x16FFF4                           | Component ID 1 Register             |
| GICDA_CIDR2     | 0x16FFF8                           | Component ID 2 Register             |
| GICDA_CIDR3     | 0x16FFFC                           | Component ID 3 Register             |

#### 2.7.4 Register Description

For detailed register description, please refer to *Arm® CoreLink™ GIC-600 Generic Interrupt Controller Technical Reference Manual* and *Arm® Generic Interrupt Controller Architecture Specification GIC architecture version 3 and version 4*.

## 2.8 Core-Local Interrupt Controller (CLIC)

### 2.8.1 Overview

The Core-Local Interrupt Controller (CLIC) is only used for sampling, priority arbitration and distribution for external interrupt sources.

- supports RISC-V Core-Local Interrupt Controller Version 0.8 specification
- Up to 144 interrupt source sampling, supporting level interrupt and pulse interrupt
- 32 levels of interrupt priority
- 4 memory-mapped control registers for each interrupt
- Each attribute of this interrupt source can be configured by writing the control register of the corresponding interrupt source.

### 2.8.2 Functional Description

The following table describes the detail of interrupt sources.

Table 2-16 Interrupt Sources

| Interrupt Number | Interrupt Source     | Interrupt Vector | Description                          |
|------------------|----------------------|------------------|--------------------------------------|
| 0-15             | Reserved             | 0x0000-0x003C    | Not Used                             |
| 16               | RISCV_WDT            | 0x0040           | RISCV watchdog interrupt             |
| 17               | RISCV_MSGBOX_RISCV   | 0x0044           | RISCV MSGBOX read IRQ                |
| 18               |                      | 0x0048           |                                      |
| 19               |                      | 0x004C           |                                      |
| 20               |                      | 0x0050           |                                      |
| 21               |                      | 0x0054           |                                      |
| 22               |                      | 0x0058           |                                      |
| 23               |                      | 0x005C           |                                      |
| 24               |                      | 0x0060           |                                      |
| 25               | MCU_TIMER0           | 0x0064           |                                      |
| 26               | MCU_TIMER1           | 0x0068           |                                      |
| 27               | MCU_TIMER2           | 0x006C           |                                      |
| 28               | AHB0_HREADY_TIME_OUT | 0x0070           | MCU AHB decoder0 timer out interrupt |
| 29               | AHB1_HREADY_TIME_OUT | 0x0074           | MCU AHB decoder1 timer out interrupt |
| 30               | AUDIO CODEC          | 0x0078           | Audio Codec IRQ                      |
| 31               | DMIC                 | 0x007C           | DMIC IRQ                             |
| 32               | I2S0                 | 0x0080           | I2S0 IRQ                             |
| 33               | I2S1                 | 0x0084           | I2S1 IRQ                             |

| Interrupt Number | Interrupt Source | Interrupt Vector | Description                               |
|------------------|------------------|------------------|-------------------------------------------|
| 34               | I2S2             | 0x0088           | I2S2 IRQ                                  |
| 35               | I2S3             | 0x008C           | I2S3 IRQ                                  |
| 36               | OWA              | 0x0090           | OWA IRQ                                   |
| 37               | MCU_DMAC_NS      | 0x0094           | MCU DMAC channel IRQ<br>non-secure to MCU |
| 38               | MCU_DMAC_S       | 0x0098           | MCU DMAC channel IRQ secure<br>to MCU     |
| 39               |                  | 0x009C           |                                           |
| 40               |                  | 0x00A0           |                                           |
| 41               | MCU_TIMER3       | 0x00A4           |                                           |
| 42               | MCU_TIMER4       | 0x00A8           |                                           |
| 43               | MCU_TIMER5       | 0x00AC           |                                           |
| 44               | MCU_PWMCTRL      | 0x00B0           | MCU PWMCTRL Interrupt                     |
| 45               |                  | 0x00B4           |                                           |
| 46               |                  | 0x00B8           |                                           |
| 47               |                  | 0x00BC           |                                           |
| 48               |                  | 0x00C0           |                                           |
| 49               |                  | 0x00C4           |                                           |
| 50               |                  | 0x00C8           |                                           |
| 51               |                  | 0x00CC           |                                           |
| 52               | NMI              | 0x00D0           | NMI interrupt in CPUS domain              |
| 53               | S_PPU            | 0x00D4           | PCK600 Q-channel Interrupt                |
| 54               | S_PPU1           | 0x00D8           | /                                         |
| 55               | S_TWD            | 0x00DC           | S_TWD interrupt                           |
| 56               | CPUS_WDT         | 0x00E0           | CPUS_WDT interrupt                        |
| 57               | CPUS_TIMER0      | 0x00E4           | CPUS_TIMER0 interrupt                     |
| 58               | CPUS_TIMER1      | 0x00E8           | CPUS_TIMER1 interrupt                     |
| 59               | CPUS_TIMER2      | 0x00EC           | CPUS_TIMER2 interrupt                     |
| 60               | S_TWI2           | 0x00F0           |                                           |
| 61               | ALARM            | 0x00F4           | RTC ALARM0 interrupt                      |
| 62               | GPIO_L_S         | 0x00F8           |                                           |
| 63               | GPIO_L_NS        | 0x00FC           |                                           |
| 64               | GPIO_M_S         | 0x0100           |                                           |
| 65               | GPIO_M_NS        | 0x0104           |                                           |
| 66               | S_UART0          | 0x0108           | S_UART0 interrupt                         |
| 67               | S_UART1          | 0x010C           |                                           |
| 68               | S_TWI0           | 0x0110           |                                           |
| 69               | S_TWI1           | 0x0114           |                                           |
| 70               |                  | 0x0118           |                                           |
| 71               | S_CIRRX          | 0x011C           | S_CIRRX interrupt                         |
| 72               | S_PWMCTRL        | 0x0120           | S_PWMCTRL interrupt                       |

| Interrupt Number | Interrupt Source  | Interrupt Vector | Description                                                                                                                                                                                 |
|------------------|-------------------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 73               |                   | 0x0124           |                                                                                                                                                                                             |
| 74               | AHBS_HREADY_TOUT  | 0x0128           | AHBS TIMEOUT interrupt in CPUS domain                                                                                                                                                       |
| 75               | PCK600_CPU        | 0x012C           | CPUIDLE(PCK600_CPU) interrupt                                                                                                                                                               |
| 76               | S_SPI             | 0x0130           | S_SPI interrupt                                                                                                                                                                             |
| 77               | S_SPINLOCK        | 0x0134           | S_SPINLOCK interrupt                                                                                                                                                                        |
| 78               | CPUS_MSGBOX_CPUX  | 0x0138           | CPUS MSGBOX write IRQ for CPUX                                                                                                                                                              |
| 79               |                   | 0x013C           |                                                                                                                                                                                             |
| 80               |                   | 0x0140           |                                                                                                                                                                                             |
| 81               | CPUS_MSGBOX_RISCV | 0x0144           | CPUS MSGBOX write IRQ for RISCV                                                                                                                                                             |
| 82               |                   | 0x0148           |                                                                                                                                                                                             |
| 83               | INT_SCRI[0]       | 0x014C           | CPUX_MSGBOX_IRQ_RISCV                                                                                                                                                                       |
| 84               | INT_SCRI[1]       | 0x0150           | CPUX_MSGBOX_IRQ_CPUS                                                                                                                                                                        |
| 85               | INT_SCRI[2]       | 0x0154           | SPLOCK_IRQ                                                                                                                                                                                  |
| 86               |                   | 0x0158           |                                                                                                                                                                                             |
| 87               | INT_SCRI[4]       | 0x015C           |                                                                                                                                                                                             |
| 88               | INT_SCRI[5]       | 0x0160           | DMAC_IRQ1_NS                                                                                                                                                                                |
| 89               | INT_SCRI[6]       | 0x0164           | DMAC_IRQ1_S                                                                                                                                                                                 |
| 90               | INT_SCRI[7]       | 0x0168           | GIC IRQ 32-39<br>Group Interrupt, the corresponding interrupt group mask register is <a href="#">GINTC_CONFIG_REG0[7:0]</a> in S_INTC.<br>Group GIC IRQ bit [33:32] are fixed to be masked. |
| 91               | INT_SCRI[8]       | 0x016C           | GIC IRQ 40-47<br>Group Interrupt, the corresponding interrupt group mask register is <a href="#">GINTC_CONFIG_REG0[15:8]</a> in S_INTC.                                                     |
| 92               | INT_SCRI[9]       | 0x0170           | GIC IRQ 48-55<br>Group Interrupt, the corresponding interrupt group mask register is <a href="#">GINTC_CONFIG_REG0[23:16]</a> in S_INTC.                                                    |

| Interrupt Number | Interrupt Source | Interrupt Vector | Description                                                                                                                                                                                    |
|------------------|------------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 93               | INT_SCRI[10]     | 0x0174           | GIC IRQ 56-63<br>Group Interrupt, the corresponding interrupt group mask register is <a href="#">GINTC_CONFIG_REG0</a> [31:24] in S_INTC.                                                      |
| 94               | INT_SCRI[11]     | 0x0178           | GIC IRQ 64-71<br>Group Interrupt, the corresponding interrupt group mask register is <a href="#">GINTC_CONFIG_REG1</a> [7:0] in S_INTC.                                                        |
| 95               | INT_SCRI[12]     | 0x017C           | GIC IRQ 72-79<br>Group Interrupt, the corresponding interrupt group mask register is <a href="#">GINTC_CONFIG_REG1</a> [15:8] in S_INTC.                                                       |
| 96               | INT_SCRI[13]     | 0x0180           | GIC IRQ 80-87<br>Group Interrupt, the corresponding interrupt group mask register is <a href="#">GINTC_CONFIG_REG1</a> [23:16] in S_INTC.<br>Group GIC IRQ bit [83:82] are fixed to be masked. |
| 97               | INT_SCRI[14]     | 0x0184           | GIC IRQ 88-95<br>Group Interrupt, the corresponding interrupt group mask register is <a href="#">GINTC_CONFIG_REG1</a> [31:24] in S_INTC.                                                      |
| 98               | INT_SCRI[15]     | 0x0188           | GIC IRQ 96-103<br>Group Interrupt, the corresponding interrupt group mask register is <a href="#">GINTC_CONFIG_REG2</a> [7:0] in S_INTC.                                                       |
| 99               | INT_SCRI[16]     | 0x018C           | GIC IRQ 104-111<br>Group Interrupt, the corresponding interrupt group mask register is                                                                                                         |

| Interrupt Number | Interrupt Source | Interrupt Vector | Description                                                                                                                                |
|------------------|------------------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------|
|                  |                  |                  | <a href="#">GINTC_CONFIG_REG2[15:8]</a> in S_INTC.                                                                                         |
| 100              | INT_SCR1[17]     | 0x0190           | GIC IRQ 112-119<br>Group Interrupt, the corresponding interrupt group mask register is <a href="#">GINTC_CONFIG_REG2[23:16]</a> in S_INTC. |
| 101              | INT_SCR1[18]     | 0x0194           | GIC IRQ 120-127<br>Group Interrupt, the corresponding interrupt group mask register is <a href="#">GINTC_CONFIG_REG2[31:24]</a> in S_INTC. |
| 102              | INT_SCR1[19]     | 0x0198           | GIC IRQ 128-135<br>Group Interrupt, the corresponding interrupt group mask register is <a href="#">GINTC_CONFIG_REG3[7:0]</a> in S_INTC.   |
| 103              | INT_SCR1[20]     | 0x019C           | GIC IRQ 136-143<br>Group Interrupt, the corresponding interrupt group mask register is <a href="#">GINTC_CONFIG_REG3[15:8]</a> in S_INTC.  |
| 104              | INT_SCR1[21]     | 0x01A0           | GIC IRQ 144-151<br>Group Interrupt, the corresponding interrupt group mask register is <a href="#">GINTC_CONFIG_REG3[23:16]</a> in S_INTC. |
| 105              | INT_SCR1[22]     | 0x01A4           | GIC IRQ 152-159<br>Group Interrupt, the corresponding interrupt group mask register is <a href="#">GINTC_CONFIG_REG3[31:24]</a> in S_INTC. |
| 106              | INT_SCR1[23]     | 0x01A8           | GIC IRQ 160-167<br>Group Interrupt, the corresponding interrupt group mask register is                                                     |

| Interrupt Number | Interrupt Source | Interrupt Vector | Description                                                                                                                                                                                       |
|------------------|------------------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  |                  |                  | <a href="#">GINTC_CONFIG_REG4[7:0]</a> in S_INTC.                                                                                                                                                 |
| 107              | INT_SCRI[24]     | 0x01AC           | GIC IRQ 168-175<br>Group Interrupt, the corresponding interrupt group mask register is <a href="#">GINTC_CONFIG_REG4[15:8]</a> in S_INTC.                                                         |
| 108              | INT_SCRI[25]     | 0x01B0           | GIC IRQ 176-183<br>Group Interrupt, the corresponding interrupt group mask register is <a href="#">GINTC_CONFIG_REG4[23:16]</a> in S_INTC.<br>Group GIC IRQ bit [183:180] are fixed to be masked. |
| 109              |                  | 0x01B4           |                                                                                                                                                                                                   |
| 110              |                  | 0x01B8           |                                                                                                                                                                                                   |
| 111              |                  | 0x01BC           |                                                                                                                                                                                                   |
| 112              |                  | 0x01C0           |                                                                                                                                                                                                   |
| 113              |                  | 0x01C4           |                                                                                                                                                                                                   |
| 114              |                  | 0x01C8           |                                                                                                                                                                                                   |
| 115              |                  | 0x01CC           |                                                                                                                                                                                                   |
| 116              |                  | 0x01D0           |                                                                                                                                                                                                   |
| 117              |                  | 0x01D4           |                                                                                                                                                                                                   |
| 118              |                  | 0x01D8           |                                                                                                                                                                                                   |
| 119              |                  | 0x01DC           |                                                                                                                                                                                                   |
| 120              |                  | 0x01E0           |                                                                                                                                                                                                   |
| 121              |                  | 0x01E4           |                                                                                                                                                                                                   |
| 122              |                  | 0x01E8           |                                                                                                                                                                                                   |
| 123              |                  | 0x01EC           |                                                                                                                                                                                                   |
| 124              |                  | 0x01F0           |                                                                                                                                                                                                   |
| 125              |                  | 0x01F4           |                                                                                                                                                                                                   |
| 126              |                  | 0x01F8           |                                                                                                                                                                                                   |
| 127              |                  | 0x01FC           |                                                                                                                                                                                                   |
| 128              |                  | 0x0200           |                                                                                                                                                                                                   |
| 129              |                  | 0x0204           |                                                                                                                                                                                                   |
| 130              |                  | 0x0208           |                                                                                                                                                                                                   |
| 131              |                  | 0x020C           |                                                                                                                                                                                                   |
| 132              |                  | 0x0210           |                                                                                                                                                                                                   |
| 133              |                  | 0x0214           |                                                                                                                                                                                                   |

| Interrupt Number | Interrupt Source | Interrupt Vector | Description |
|------------------|------------------|------------------|-------------|
| 134              |                  | 0x0218           |             |
| 135              |                  | 0x021C           |             |
| 136              |                  | 0x0220           |             |
| 137              |                  | 0x0224           |             |
| 138              |                  | 0x0228           |             |
| 139              |                  | 0x022C           |             |
| 140              |                  | 0x0230           |             |
| 141              |                  | 0x0234           |             |
| 142              |                  | 0x0238           |             |
| 143              |                  | 0x023C           |             |
| 144              |                  | 0x0240           |             |

### 2.8.3 Register List

#### 2.8.3.1 CLIC Register List

| Module Name | Base Address |
|-------------|--------------|
| RISCV CLIC  | 0xE080_0000  |

| Register Name       | Offset     | Description                 |
|---------------------|------------|-----------------------------|
| CLIC_CFG_REG        | 0x0000     | CLIC Configuration Register |
| CLIC_MINTTHRESH_REG | 0x0008     | CLIC MINTTHRESH Register    |
| CLIC_INT_REGn       | 0x1000+n*4 | CLIC Interrupt Register n   |

#### 2.8.3.2 S\_INTC Register List

| Module Name | Base Address |
|-------------|--------------|
| S_INTC      | 0x0702_1000  |

| Register Name     | Offset | Description                              |
|-------------------|--------|------------------------------------------|
| GINTC_CONFIG_REG0 | 0x00C0 | Group Interrupt Configuration Register 0 |
| GINTC_CONFIG_REG1 | 0x00C4 | Group Interrupt Configuration Register 1 |
| GINTC_CONFIG_REG2 | 0x00C8 | Group Interrupt Configuration Register 2 |
| GINTC_CONFIG_REG3 | 0x00CC | Group Interrupt Configuration Register 3 |
| GINTC_CONFIG_REG4 | 0x00D0 | Group Interrupt Configuration Register 4 |

## 2.8.4 CLIC Register description

### 2.8.4.1 0x0000 CLIC Configuration Register (Default Value: 0x0000\_0000)

| Offset: 0x0000 |            |             | Register Name: CLICCFG_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 31:7           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 6:5            | R/W        | 0x0         | NM<br>Indicates the effective number of bits in privilege mode.<br>RISC-V only supports to process interrupt requests in machine mode whatever the value of CLICINTATTR MODE bit in CLIC_INT_REGn register is. The value of this bit is always 0.                                                                                                                                                                                                                                                                            |
| 4:1            | R/W        | 0x0         | NL<br>Indicates the effective number of interrupt priority level bits.<br>The number of bits is fixed at 8. You can fill the empty bits with 1.                                                                                                                                                                                                                                                                                                                                                                              |
| 0              | R/W        | 0x1         | NV<br>Indicates the interrupt flag in hardware vector mode.<br>This bit is fixed at 1 and this indicates that the CLIC controller supports hardware vector mode interrupt. RISC-V could perform a hardware two-stage jump to obtain the service program entry address of the hardware vector interrupt. RISC-V fetches the entry address from MVT+ interrupt ID*4 after saving the processor field. Then RISC-V jumps to this address to process interrupt.<br>The entry address of other mode interrupts is MTVEC[31:6]<<6. |

### 2.8.4.2 0x0008 CLIC\_MINTTHRESH\_REG (Default Value: 0x0000\_0000)

| Offset: 0x0008 |            |             | Register Name: CLIC_MINTTHRESH_REG |
|----------------|------------|-------------|------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                        |
| 31:24          | R/W        | 0x0         | MTH<br>Machine Mode Threshold      |
| 23:0           | /          | /           | /                                  |

### 2.8.4.3 0x1000+n\*0x4 CLIC Interrupt Register n (Default Value: 0x07C0\_0000)

| Offset: 0x1000+n*0x4 |            |             | Register Name: CLIC_INT_REGn |
|----------------------|------------|-------------|------------------------------|
| Bit                  | Read/Write | Default/Hex | Description                  |
| 31:27                | R/W        | 0x0         | CLICINTCTL PRIO              |

| Offset: 0x1000+n*0x4 |            |             | Register Name: CLIC_INT_REGn                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|----------------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                  | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                      |            |             | Interrupt Priority Level                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 26:24                | /          | 0x3         | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 23:22                | R/W        | 0x3         | CLICINTATTR MODE<br>Interrupt Privilege Mode<br>RISC-V only supports to process interrupt requests in machine mode. The value of this bit is always 2'b11.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 21:19                | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 18:17                | R/W        | 0x0         | CLICINTATTR TRIG<br>Interrupt Trigger<br>Used to distinguish interrupt trigger mode.<br>CLICINTATTR TRIG [0] = 0: Level Interrupt<br>CLICINTATTR TRIG [0] = 1: Pulse Interrupt<br>CLICINTATTR TRIG [1] =0: Triggered on Rising Edge<br>CLICINTATTR TRIG[1]=1: Triggered on Falling Edge                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 16                   | R/W        | 0x0         | CLICINTATTR SHV<br>Hardware Vector Interrupt<br>Indicates whether the interrupt is in hardware vector mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 15:9                 | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 8                    | R/W        | 0x0         | CLICINTIE<br>Interrupt Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 7:1                  | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 0                    | R/W        | 0x0         | CLICINTIP<br>Interrupt Pending<br><b>Level Interrupt Mode</b><br>the CLICINTIP bit is read-only. To modify the value of this bit, you could set the external interrupt source directly:<br>If external interrupt source is high level, IP = 1.<br>If external interrupt source is low level, IP =0.<br><b>Pulse Interrupt Mode</b><br>the CLICINTIP bit can be read or written.<br>In hardware vector mode:<br>The IP can be cleared automatically while RISC-V responds interrupt requests.<br>In non-hardware vector mode:<br>While RISC-V executes a CSR command, it is suggested to perform effective reading and writing operations on MNXTI register to obtain the waiting status of interrupt and the corresponding value of IP will be cleared automatically at the same time.<br>If the interrupt request is transmitted to the RISC-V pipeline |

| Offset: 0x1000+n*0x4 |            |             | Register Name: CLIC_INT_REGn                                                                                                          |
|----------------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------|
| Bit                  | Read/Write | Default/Hex | Description                                                                                                                           |
|                      |            |             | core directly, hardware is not able to clear the value of IP when RISC-V responds this interrupt. It needs to be cleared by software. |

## 2.8.5 S\_INTC Register Description

### 2.8.5.1 0x00C0 Group Interrupt Configuration Register 0 (Default Value:0x0000\_0000)

| Offset: 0x00C0 |            |             | Register Name: GINTC_CONFIG_REG0                                                                                                                                                                 |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                      |
| 31:0           | R/W        | 0x0         | GINT_CONFIG0.<br>Group Interrupt [31:0] Configuration Bit.<br>0: Interrupt signal will not send to interrupt controller.<br>1: Interrupt signal will send to interrupt controller if it happens. |

### 2.8.5.2 0x00C4 Group Interrupt Configuration Register 1 (Default Value:0x0000\_0000)

| Offset: 0x00C4 |            |             | Register Name: GINTC_CONFIG_REG1                                                                                                                                                                 |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                      |
| 31:0           | R/W        | 0x0         | GINT_CONFIG1<br>Group Interrupt [63:32] Configuration Bit.<br>0: Interrupt signal will not send to interrupt controller.<br>1: Interrupt signal will send to interrupt controller if it happens. |

### 2.8.5.3 0x00C8 Group Interrupt Configuration Register 2 (Default Value:0x0000\_0000)

| Offset: 0x00C8 |            |             | Register Name: GINTC_CONFIG_REG2                                                                                                                                                                 |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                      |
| 31:0           | R/W        | 0x0         | GINT_CONFIG2<br>Group Interrupt [95:64] Configuration Bit.<br>0: Interrupt signal will not send to interrupt controller.<br>1: Interrupt signal will send to interrupt controller if it happens. |

### 2.8.5.4 0x00CC Group Interrupt Configuration Register 3 (Default Value:0x0000\_0000)

| Offset: 0x00CC | Register Name: GINTC_CONFIG_REG3 |
|----------------|----------------------------------|
|----------------|----------------------------------|

| Bit  | Read/Write | Default/Hex | Description                                                                                                                                                                                        |
|------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | R/W        | 0x0         | GINT_CONFIG3.<br>Group Interrupt [127:96] Configuration Bit.<br>0: Interrupt signal will not send to interrupt controller.<br>1: Interrupt signal will send to interrupt controller if it happens. |

#### 2.8.5.5 0x00D0 Group Interrupt Configuration Register 4 (Default Value:0x0000\_0000)

| Offset: 0x00D0 |            |             | Register Name: GINTC_CONFIG_REG4                                                                                                                                                                    |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                         |
| 31:0           | R/W        | 0x0         | GINT_CONFIG4.<br>Group Interrupt [159:128] Configuration Bit.<br>0: Interrupt signal will not send to interrupt controller.<br>1: Interrupt signal will send to interrupt controller if it happens. |

## 2.9 I/O Memory Management Unit (IOMMU)

### 2.9.1 Overview

IOMMU (I/O Memory management unit) is designed for the specific memory requirements. It maps the virtual address (sent by the peripheral access memory) to the physical address. IOMMU allows multiple ways to manage the location of the physical address. It can use the physical address which has the potentially conflict mapping for different processes to allocate the memory space, and also allow application of non-continuous address mapping to the continuous virtual address space.

The IOMMU has the following features:

- Supports virtual address to physical address mapping by hardware implementation
- Supports ISP, CSI, VE\_MBUS0, VE\_MBUS1, G2D, DE, and DI parallel address mapping
- Supports ISP, CSI, VE\_MBUS0, VE\_MBUS1, G2D, DE, and DI bypass function independently
- Supports ISP, CSI, VE\_MBUS0, VE\_MBUS1, G2D, DE, and DI pre-fetch independently
- Supports ISP, CSI, VE\_MBUS0, VE\_MBUS1, G2D, DE, and DI interrupt handing mechanism independently
- Supports 2 levels TLB (level1 TLB for special using, and level2 TLB for sharing)
- Supports TLB Fully cleared and Partially disabled
- Supports trigger PTW behavior when TLB miss
- Supports checking the permission

### 2.9.2 Block Diagram

The internal module of IOMMU mainly includes the following parts.

**Micro TLB:** Level1 TLB, 64 words. Each peripheral corresponds to a TLB, which caching the level2 page table for the peripheral.

**Macro TLB:** Level2 TLB, 4K words. Each peripheral shares a level2 TLB for caching the level2 page table.

**Pre-fetch Logic:** Each Micro TLB corresponds to a Pre-fetch Logic. By monitoring each master device to predict the bus access, the secondary page table corresponding to the address to be accessed can be read from the memory and stored in the secondary TLB to improve the hit ratio.

**PTW Logic:** Page Table Walk, mainly contains PTW Cache and PTW. The PTW Cache is used to store the level1 page table; when the virtual address is missed in the level1 and level2 TLB, it will trigger the PTW. PTW Cache can store 512 level1 page tables, that is, 512 words.

**PMU:** Performance Monitoring Unit, which is used to count the hit efficiency and the latency.

**APB Interface:** IOMMU register instantiation module. CPU reads and writes the IOMMU register by APB bus.

The following figure shows the internal block diagram of IOMMU.

**Figure 2-16 IOMMU Block Diagram**



**Table 2-17 Correspondence Relation between Master and Module**

| Master number | module    |
|---------------|-----------|
| Master0       | ISP       |
| Master1       | CSI       |
| Master2       | VE_MBUSH0 |
| Master3       | VE_MBUSH1 |
| Master4       | G2D       |
| Master5       | DE        |
| Master6       | DI        |

## 2.9.3 Functional Descriptions

### 2.9.3.1 Initialization

- Release the IOMMU reset signal by writing 1 to the bit[31] of the [IOMMU\\_RESET\\_REG \(Offset: 0x0010\)](#);
- Write the base address of the first TLB to the [IOMMU\\_TTB\\_REG \(Offset: 0x0050\)](#);
- Set the [IOMMU\\_INT\\_ENABLE\\_REG \(Offset: 0x0100\)](#);
- Enable the IOMMU by configuring the [IOMMU\\_ENABLE\\_REG \(Offset: 0x0020\)](#) in the final.

### 2.9.3.2 Address Translation

In the process of address mapping, the peripheral virtual address [31:12] are retrieved in the Level1 TLB. When TLB is hit, the mapping is finished. Otherwise, they are retrieved in the Level2 TLB in the same way. If TLB is hit, the hit mapping will be written to the Level1 TLB, and hit in Level1 TLB. If Level1 and Level2 TLB are retrieved fail, the PTW will be triggered. After opening the peripheral bypass function by setting [IOMMU\\_BYPASS\\_REG \(Offset: 0x0030\)](#), IOMMU will not map the address typed by this peripheral, and it will output the virtual address as the physical address. The typical applications are as follows.

#### Micro TLB hit

- Step 1** The master device sends a transfer command, and also sends the address to the corresponding Micro TLB to search the Level2 page table related to the virtual address;
- Step 2** If Micro TLB is hit, it will return a Level2 page table containing the corresponding physical addresses and the permission Index;
- Step 3** The address translation module converts the virtual address into the physical address, and checks the permissions at the same time. If it is passed, the transfer is completed.

#### Micro TLB miss, Macro TLB hit

- Step 1** The master device sends a transfer command, and also sends the address to the corresponding Micro TLB to search the Level2 page table related to the virtual address;
- Step 2** If Micro TLB is missed, continue to search Macro TLB;
- Step 3** If Macro TLB is hit, it will return the Level2 page table to Micro TLB;
- Step 4** Micro TLB receives this page table, puts it in Micro TLB (If this Micro TLB is full, the replace activities will happen), and sends the page table to the address translation module at the same time;
- Step 5** The address translation module converts the virtual address into the physical address, and checks the permissions at the same time. If it is passed, the transfer is completed.

#### Micro TLB miss, Macro TLB miss, PTW Cache hit

- Step 1** The master device sends a transfer command, and also sends the address to the corresponding Micro TLB to search the Level2 page table related to the virtual address;
- Step 2** If Micro TLB is missed, continue to search Macro TLB;
- Step 3** If Macro TLB is missed, send the request to the PTW to return the corresponding page table;
- Step 4** PTW first accesses PTW Cache. If the required Level1 page table exists in the PTW Cache, send the page table to PTW logic;

- Step 5** PTW logic returns the corresponding Level2 page table from the memory page table according to the Level1 page table, checks the effectiveness, and sends it to Macro TLB;
- Step 6** Macro TLB stores the Level2 page table (the replace activities may happen), and returns the Level2 page table to Micro TLB;
- Step 7** Micro TLB receives this page table, puts it in the Micro TLB (if this Micro TLB is full, the replace activities will happen), and sends the page table to the address translation module at the same time;
- Step 8** The address translation module converts the virtual address into the physical address, and checks the permissions at the same time. If it is passed, the transfer is completed.

#### **Micro TLB miss, Macro TLB miss, PTW Cache miss**

- Step 1** The master device sends a transfer command, and also sends the address to the corresponding Micro TLB to search the Level2 page table related to the virtual address;
- Step 2** If Micro TLB is missed, continue to search Macro TLB;
- Step 3** If Macro TLB is missed, send the request to the PTW to return the corresponding page table;
- Step 4** PTW accesses PTW Cache, there is no necessary Level1 page table;
- Step 5** PTW accesses the memory, gets the corresponding Level1 page table and stores it in the PTW Cache (the replace activities may happen);
- Step 6** PTW logic returns the corresponding Level2 page table from the memory page table according to the Level1 page table, checks the effectiveness, and sends it to Macro TLB;
- Step 7** Macro TLB stores the Level2 page table (the replace activities may happen), and returns the Level2 page table to Micro TLB;
- Step 8** Micro TLB receives this page table, puts it in the Micro TLB (if this Micro TLB is full, the replace activities will happen), and sends the page table to the address translation module at the same time;
- Step 9** The address translation module converts the virtual address into the physical address, and checks the permissions at the same time. If it is passed, the transfer is completed.

#### **Permission error**

- Step 1** The permission checking is always performed during the process of translating the address;
- Step 2** Once the permission checking makes mistake, the new access of the master suspends, but the access before this checking can be continued;
- Step 3** Set the error status register;

---

**Step 4** Trigger the interrupt.

#### Invalid Level1 page table

- Step 1** The invalid Level1 page table is checked when PTW logic reads the new level page table from the memory;
- Step 2** The PTW reads two sequential page table entries from the memory (64-bit data, a complete cache line), and stores them in the PTW cache;
- Step 3** If the current page table is invalid, the error flag is set and the interrupt is triggered. The cache line needs to be invalidated.
- 



#### NOTE

- Invalid page table has two situations: the reading target page table from the memory is invalid, or the page table stored in PTW Cache with target page table is found to be invalid after using;
  - If a page table is invalid, invalidate the total cache line (that is two page tables).
- 

#### Invalid Level2 page table

- Step 1** The invalid Level2 page table is checked when Macro TLB reads the new level page table from the memory;
- Step 2** The Macro TLB reads two sequential page table entries from the memory (64-bit data, a complete cache line), and stores them in the Macro TLB;
- Step 3** If the current page table is invalid, the error flag is set and the interrupt is triggered. The cache line needs to be invalidated.
- 



#### NOTE

- Invalid page table has two situations: the reading target page table from the memory is invalid, or the page table stored in Macro TLB with target page table is found to be invalid after using;
  - If a page table is invalid, invalidate the total cache line (that is two page tables).
-

The internal address translation process is shown in the following figure.

**Figure 2-17 Internal Switch Process**



### 2.9.3.3 VA-PA Mapping

IOMMU page table is defined as the Level2 mapping. The first level is 1M address space mapping, the second level is 4K address space. This version does not support 1K, 16K and other page table sizes. IOMMU only supports a page table, the meaning is:

- All peripherals connected to IOMMU use the same virtual address space;
- The virtual address space of the peripherals can overlap;
- Different virtual addresses can map to the same physical address space;

Base address of this page table is defined by the software, and it needs 16 KB address alignment. The page table of the Level2 table item needs 1 KB address alignment. A complete VA-PA address translation process is shown in the following figure.

Figure 2-18 VA-PA Switch Process



#### 2.9.3.4 Clearing and Invalidating TLB

When multi page table contents are refreshed or table address changes, all VA-PA mappings which have been cached in TLB will be invalid. You need to configure **IOMMU\_TLB\_FLUSH\_ENABLE\_REG** (Offset: 0x0080) to clear the TLB or PTW Cache according to the following steps:

**Step 1** Suspend the access to TLB or Cache.

**Step 2** Configure the corresponding Flush bit of **IOMMU\_TLB\_FLUSH\_ENABLE\_REG** (Offset: 0x0080).

**Step 3** After the operation takes effect, the related peripherals can continue to send the new access memory operations.

When some page table is invalid or the mapping is incorrect, you can set the TLB Invalidation relevant register to invalidate TLB VA-PA mapping pairs. The invalid TLB supports the following two modes:

- Mode0

**Step 1** Set **IOMMU\_TLB\_IVLD\_MODE\_SEL\_REG** (Offset: 0x0084) to 0 and select mode0;

- Step 2** Write the target address to [IOMMU\\_TLB\\_IVLD\\_ADDR\\_REG \(Offset: 0x0090\)](#);
- Step 3** Set the configuration values to [IOMMU\\_TLB\\_IVLD\\_ADDR\\_MASK\\_REG \(Offset: 0x0094\)](#), the requirements are as follows:
- The value of [IOMMU\\_TLB\\_IVLD\\_ADDR\\_MASK\\_REG \(Offset: 0x0094\)](#) cannot be less than the IOMMU\_TLB\_IVLD\_ADDR\_REG (Offset: 0x0090).
  - The higher bit of [IOMMU\\_TLB\\_IVLD\\_ADDR\\_MASK\\_REG \(Offset: 0x0094\)](#) must be continuous 1, the lower bit must be continuous 0. For example, 0xFFFFF000, 0xFFFFE000, 0xFFFFC000, 0xFFFF8000, and 0xFFFF0000 are legal values; while 0xFFFFD000, 0xFFFFB000, 0xFFFFA000, 0xFFFF9000, and 0xFFFF7000 are illegal values.
- Step 4** Configure [IOMMU\\_TLB\\_IVLD\\_ENABLE\\_REG \(Offset: 0x0098\)](#) to enable the invalid operation. Among the way to determine the invalid address is to get the maximum valid bit and determine the target address range by the target address AND the mask address. The process is shown as follows.

Figure 2-19 Invalid TLB Address Range



The examples are shown below:

- When the value of [IOMMU\\_TLB\\_IVLD\\_ADDR\\_MASK\\_REG \(Offset: 0x0094\)](#) is 0xFFFFF000 by default, the result of AND is target address. That is, only the target address is invalid.
- When the value of [IOMMU\\_TLB\\_IVLD\\_ADDR\\_MASK\\_REG \(Offset: 0x0094\)](#) is 0xFFFF0000, the value of [IOMMU\\_TLB\\_IVLD\\_ADDR\\_REG \(0x0090\)](#) is 0xEEEE1000, then target address range is from 0xEEEE0000 to 0xEEEF000.
- When the value of [IOMMU\\_TLB\\_IVLD\\_ADDR\\_MASK\\_REG \(Offset: 0x0094\)](#) is 0xFFFFC000, the value of [IOMMU\\_TLB\\_IVLD\\_ADDR\\_REG \(0x0090\)](#) is 0xEEEE8000, then target address range is from 0xEEEE8000 to 0xEEEB000.
- When the value of [IOMMU\\_TLB\\_IVLD\\_ADDR\\_MASK\\_REG \(Offset: 0x0094\)](#) is 0xFFFF8000, the value of [IOMMU\\_TLB\\_IVLD\\_ADDR\\_REG \(0x0090\)](#) is 0xEEEC000, then target address range is from 0xEEEE8000 to 0xEEEF000.

- When the value of [IOMMU\\_TLB\\_IVLD\\_ADDR\\_MASK\\_REG](#) (Offset: 0x0094) is 0xFFFFC000, the value of [IOMMU\\_TLB\\_IVLD\\_ADDR\\_REG](#) (0x0090) is 0xEEEE0000, then target address range is from 0xEEEE0000 to 0xEEEE3000.
- Mode1

**Step 1** Set [IOMMU\\_TLB\\_IVLD\\_MODE\\_SEL\\_REG](#) (Offset: 0x0084) to 1 and select mode1;

**Step 2** Set the starting address and the ending address of the invalid TLB by [IOMMU\\_TLB\\_IVLD\\_STA\\_ADDR\\_REG](#) (Offset: 0x0088);

**Step 3** Configure [IOMMU\\_TLB\\_IVLD\\_ENABLE\\_REG](#) (Offset: 0x0098) to enable the invalid operation, then the TLB invalidating operation can be completed.

### 2.9.3.5 Clearing and Invalidating PTW Cache

- Mode0

**Step 1** Set [IOMMU\\_PC\\_IVLD\\_MODE\\_SEL\\_REG](#) (Offset: 0x009C) to 0 and select mode0.

**Step 2** Invalid the [IOMMU\\_PC\\_IVLD\\_ADDR\\_REG](#) (Offset: 0x00A0), 1MB aligned.

**Step 3** Configure [IOMMU\\_PC\\_IVLD\\_ENABLE\\_REG](#) (Offset: 0x00A8) to enable the invalid operation, then you can invalid one piece of CacheLine.

- Mode1

**Step 1** Set [IOMMU\\_PC\\_IVLD\\_MODE\\_SEL\\_REG](#) (Offset: 0x009C) to 1 and select mode1.

**Step 2** Set the starting address and the ending address of the invalid TLB by [IOMMU\\_PC\\_IVLD\\_STA\\_ADDR\\_REG](#) (Offset: 0x00A4);

**Step 3** Configure [IOMMU\\_PC\\_IVLD\\_ENABLE\\_REG](#) (Offset: 0x00A8) to enable the invalid operation, then you can invalid a period of sections.

### 2.9.3.6 Level1 Page Table

The format of Level1 page table is as follows.

**Figure 2-20 Level1 Page Table Format**

| 31                                 | 10 9     | 2 1 0 |
|------------------------------------|----------|-------|
| Start address of Level2 page table | Reserved | 01    |

Bit [31:10]: Base address of Level2 page table;

Bit [9:2]: Reserved;

Bit [1:0]: 01 is a valid page table; other values are fault;

### 2.9.3.7 Level2 Page Table

The format of Level2 page table is as follows.

Figure 2-21 Level2 Page Table Format

|                       |    |   |   |     |
|-----------------------|----|---|---|-----|
| 31                    | 12 | 7 | 4 | 1 0 |
| Physical base address |    |   |   | 1   |

Bit [31:12]: Physical address of 4K address;

Bit [11:8]: Reserved;

Bit [7:4]: ACI, permission control index; correspond to permission control bit of IOMMU Domain Authority Control Register;

Bit [3:2]: Reserved;

Bit [1]: 1 is a valid page table; 0 is fault;

Bit [0]: Reserved

## 2.9.4 Programming Guidelines

### 2.9.4.1 Resetting IOMMU

Before the IOMMU module software reset operation, make sure IOMMU is never opened, or all bus operations are completed, or DRAM and peripherals already open the corresponding switch, to shield the influence of IOMMU reset.

### 2.9.4.2 Enabling IOMMU

Before opening the IOMMU address mapping function, [IOMMU\\_TTB\\_REG \(Offset: 0x0050\)](#) should be correctly configured, or all the masters are in the bypass state, or all the masters do not send the bus command.

### 2.9.4.3 Configuring TTB

Operating the register must close IOMMU address mapping function, namely [IOMMU\\_ENABLE\\_REG \(Offset: 0x0020\)](#) is 0; or Bypass function of all masters is set to 1, or no the state of transfer bus commands.

### 2.9.4.4 Clearing TTB

In the Flush operation, all TLB/Cache access will be suspended; but the operation entered the TLB will continue to complete before the Flush starts.

#### 2.9.4.5 Reading/Writing VA Data

For the virtual address, read and write the corresponding physical address data to make sure whether IOMMU module address mapping function is normal. First, make sure to read or write, and then configure the target virtual address or write data, then start to read or write function, after the operation is finished, check if the results are as expected.

#### 2.9.4.6 PMU Statistics

When PMU function is used for the first time, set [IOMMU\\_PMU\\_ENABLE\\_REG \(Offset: 0x0200\)](#) to enable statistics function; when reading the relevant Register, clear the enable bit of [IOMMU\\_PMU\\_ENABLE\\_REG \(Offset: 0x0200\)](#); when PMU function is used next time, first [IOMMU\\_PCU\\_CLR\\_REG \(Offset: 0x0210\)](#) is set, after counter is cleared, set the enable bit of [IOMMU\\_PMU\\_ENABLE\\_REG \(Offset: 0x0200\)](#).

Given a Level2 page table administers continuous 4KB address, if Micro TLB misses in continuous virtual address, a Level2 page table needs to be returned from Macro TLB to hit; but the hit number is not recorded in the Macro TLB hit and Micro TLB hit related register. So the true hit rate calculation is as follows:

$$\text{Hit Rate} = N1/M1 + (1-N1/M1)*N2/M2$$

N1: Micro TLB hit number

M1: Micro TLB access number

N2: Macro TLB hit number

M2: Macro TLB access number

### 2.9.5 Register List

| Module Name | Base Address |
|-------------|--------------|
| IOMMU       | 0x0201_0000  |

| Register Name              | Offset | Description                                 |
|----------------------------|--------|---------------------------------------------|
| IOMMU_RESET_REG            | 0x0010 | IOMMU Reset Register                        |
| IOMMU_ENABLE_REG           | 0x0020 | IOMMU Enable Register                       |
| IOMMU_BYPASS_REG           | 0x0030 | IOMMU Bypass Register                       |
| IOMMU_AUTO_GATING_REG      | 0x0040 | IOMMU Auto Gating Register                  |
| IOMMU_WBUF_CTRL_REG        | 0x0044 | IOMMU Write Buffer Control Register         |
| IOMMU_OOO_CTRL_REG         | 0x0048 | IOMMU Out Of Order Control Register         |
| IOMMU_4KB_BDY_PRT_CTRL_REG | 0x004C | IOMMU 4KB Boundary Protect Control Register |
| IOMMU_TTB_REG              | 0x0050 | IOMMU Translation Table Base Register       |
| IOMMU_TLB_ENABLE_REG       | 0x0060 | IOMMU TLB Enable Register                   |

| Register Name                | Offset | Description                                    |
|------------------------------|--------|------------------------------------------------|
| IOMMU_TLB_PREFETCH_REG       | 0x0070 | IOMMU TLB Prefetch Register                    |
| IOMMU_TLB_FLUSH_ENABLE_REG   | 0x0080 | IOMMU TLB Flush Enable Register                |
| IOMMU_TLB_IVLD_MODE_SEL_REG  | 0x0084 | IOMMU TLB Invalidation Mode Select Register    |
| IOMMU_TLB_IVLD_STA_ADDR_REG  | 0x0088 | IOMMU TLB Invalidations Start Address Register |
| IOMMU_TLB_IVLD_END_ADDR_REG  | 0x008C | IOMMU TLB Invalidations End Address Register   |
| IOMMU_TLB_IVLD_ADDR_REG      | 0x0090 | IOMMU TLB Invalidations Address Register       |
| IOMMU_TLB_IVLD_ADDR_MASK_REG | 0x0094 | IOMMU TLB Invalidations Address Mask Register  |
| IOMMU_TLB_IVLD_ENABLE_REG    | 0x0098 | IOMMU TLB Invalidations Enable Register        |
| IOMMU_PC_IVLD_MODE_SEL_REG   | 0x009C | IOMMU PC Invalidations Mode Select Register    |
| IOMMU_PC_IVLD_ADDR_REG       | 0x00A0 | IOMMU PC Invalidations Address Register        |
| IOMMU_PC_IVLD_STA_ADDR_REG   | 0x00A4 | IOMMU PC Invalidations Start Address Register  |
| IOMMU_PC_IVLD_ENABLE_REG     | 0x00A8 | IOMMU PC Invalidations Enable Register         |
| IOMMU_PC_IVLD_END_ADDR_REG   | 0x00AC | IOMMU PC Invalidations End Address Register    |
| IOMMU_INT_ENABLE_REG         | 0x0100 | IOMMU Interrupt Enable Register                |
| IOMMU_INT_CLR_REG            | 0x0104 | IOMMU Interrupt Clear Register                 |
| IOMMU_INT_STA_REG            | 0x0108 | IOMMU Interrupt Status Register                |
| IOMMU_INT_ERR_ADDR0_REG      | 0x0110 | IOMMU Interrupt Error Address 0 Register       |
| IOMMU_INT_ERR_ADDR1_REG      | 0x0114 | IOMMU Interrupt Error Address 1 Register       |
| IOMMU_INT_ERR_ADDR2_REG      | 0x0118 | IOMMU Interrupt Error Address 2 Register       |
| IOMMU_INT_ERR_ADDR3_REG      | 0x011C | IOMMU Interrupt Error Address 3 Register       |
| IOMMU_INT_ERR_ADDR4_REG      | 0x0120 | IOMMU Interrupt Error Address 4 Register       |
| IOMMU_INT_ERR_ADDR5_REG      | 0x0124 | IOMMU Interrupt Error Address 5 Register       |
| IOMMU_INT_ERR_ADDR6_REG      | 0x0128 | IOMMU Interrupt Error Address 6 Register       |
| IOMMU_INT_ERR_ADDR7_REG      | 0x0130 | IOMMU Interrupt Error Address 7 Register       |
| IOMMU_INT_ERR_ADDR8_REG      | 0x0134 | IOMMU Interrupt Error Address 8 Register       |
| IOMMU_INT_ERR_DATA0_REG      | 0x0150 | IOMMU Interrupt Error Data 0 Register          |
| IOMMU_INT_ERR_DATA1_REG      | 0x0154 | IOMMU Interrupt Error Data 1 Register          |
| IOMMU_INT_ERR_DATA2_REG      | 0x0158 | IOMMU Interrupt Error Data 2 Register          |
| IOMMU_INT_ERR_DATA3_REG      | 0x015C | IOMMU Interrupt Error Data 3 Register          |
| IOMMU_INT_ERR_DATA4_REG      | 0x0160 | IOMMU Interrupt Error Data 4 Register          |
| IOMMU_INT_ERR_DATA5_REG      | 0x0164 | IOMMU Interrupt Error Data 5 Register          |
| IOMMU_INT_ERR_DATA6_REG      | 0x0168 | IOMMU Interrupt Error Data 6 Register          |
| IOMMU_INT_ERR_DATA7_REG      | 0x0170 | IOMMU Interrupt Error Data 7 Register          |
| IOMMU_INT_ERR_DATA8_REG      | 0x0174 | IOMMU Interrupt Error Data 8 Register          |
| IOMMU_L1PG_INT_REG           | 0x0180 | IOMMU L1 Page Table Interrupt Register         |
| IOMMU_L2PG_INT_REG           | 0x0184 | IOMMU L2 Page Table Interrupt Register         |
| IOMMU_VA_REG                 | 0x0190 | IOMMU Virtual Address Register                 |
| IOMMU_VA_DATA_REG            | 0x0194 | IOMMU Virtual Address Data Register            |
| IOMMU_VA_CONFIG_REG          | 0x0198 | IOMMU Virtual Address Configuration Register   |
| IOMMU_PMU_ENABLE_REG         | 0x0200 | IOMMU PMU Enable Register                      |

| Register Name              | Offset | Description                         |
|----------------------------|--------|-------------------------------------|
| IOMMU_PMU_CLR_REG          | 0x0210 | IOMMU PMU Clear Register            |
| IOMMU_PMU_ACCESS_LOW0_REG  | 0x0230 | IOMMU PMU Access Low 0 Register     |
| IOMMU_PMU_ACCESS_HIGH0_REG | 0x0234 | IOMMU PMU Access High 0 Register    |
| IOMMU_PMU_HIT_LOW0_REG     | 0x0238 | IOMMU PMU Hit Low 0 Register        |
| IOMMU_PMU_HIT_HIGH0_REG    | 0x023C | IOMMU PMU Hit High 0 Register       |
| IOMMU_PMU_ACCESS_LOW1_REG  | 0x0240 | IOMMU PMU Access Low 1 Register     |
| IOMMU_PMU_ACCESS_HIGH1_REG | 0x0244 | IOMMU PMU Access High 1 Register    |
| IOMMU_PMU_HIT_LOW1_REG     | 0x0248 | IOMMU PMU Hit Low 1 Register        |
| IOMMU_PMU_HIT_HIGH1_REG    | 0x024C | IOMMU PMU Hit High 1 Register       |
| IOMMU_PMU_ACCESS_LOW2_REG  | 0x0250 | IOMMU PMU Access Low 2 Register     |
| IOMMU_PMU_ACCESS_HIGH2_REG | 0x0254 | IOMMU PMU Access High 2 Register    |
| IOMMU_PMU_HIT_LOW2_REG     | 0x0258 | IOMMU PMU Hit Low 2 Register        |
| IOMMU_PMU_HIT_HIGH2_REG    | 0x025C | IOMMU PMU Hit High 2 Register       |
| IOMMU_PMU_ACCESS_LOW3_REG  | 0x0260 | IOMMU PMU Access Low 3 Register     |
| IOMMU_PMU_ACCESS_HIGH3_REG | 0x0264 | IOMMU PMU Access High 3 Register    |
| IOMMU_PMU_HIT_LOW3_REG     | 0x0268 | IOMMU PMU Hit Low 3 Register        |
| IOMMU_PMU_HIT_HIGH3_REG    | 0x026C | IOMMU PMU Hit High 3 Register       |
| IOMMU_PMU_ACCESS_LOW4_REG  | 0x0270 | IOMMU PMU Access Low 4 Register     |
| IOMMU_PMU_ACCESS_HIGH4_REG | 0x0274 | IOMMU PMU Access High 4 Register    |
| IOMMU_PMU_HIT_LOW4_REG     | 0x0278 | IOMMU PMU Hit Low 4 Register        |
| IOMMU_PMU_HIT_HIGH4_REG    | 0x027C | IOMMU PMU Hit High 4 Register       |
| IOMMU_PMU_ACCESS_LOW5_REG  | 0x0280 | IOMMU PMU Access Low 5 Register     |
| IOMMU_PMU_ACCESS_HIGH5_REG | 0x0284 | IOMMU PMU Access High 5 Register    |
| IOMMU_PMU_HIT_LOW5_REG     | 0x0288 | IOMMU PMU Hit Low 5 Register        |
| IOMMU_PMU_HIT_HIGH5_REG    | 0x028C | IOMMU PMU Hit High 5 Register       |
| IOMMU_PMU_ACCESS_LOW6_REG  | 0x0290 | IOMMU PMU Access Low 6 Register     |
| IOMMU_PMU_ACCESS_HIGH6_REG | 0x0294 | IOMMU PMU Access High 6 Register    |
| IOMMU_PMU_HIT_LOW6_REG     | 0x0298 | IOMMU PMU Hit Low 6 Register        |
| IOMMU_PMU_HIT_HIGH6_REG    | 0x029C | IOMMU PMU Hit High 6 Register       |
| IOMMU_PMU_ACCESS_LOW7_REG  | 0x02D0 | IOMMU PMU Access Low 7 Register     |
| IOMMU_PMU_ACCESS_HIGH7_REG | 0x02D4 | IOMMU PMU Access High 7 Register    |
| IOMMU_PMU_HIT_LOW7_REG     | 0x02D8 | IOMMU PMU Hit Low 7 Register        |
| IOMMU_PMU_HIT_HIGH7_REG    | 0x02DC | IOMMU PMU Hit High 7 Register       |
| IOMMU_PMU_ACCESS_LOW8_REG  | 0x02E0 | IOMMU PMU Access Low 8 Register     |
| IOMMU_PMU_ACCESS_HIGH8_REG | 0x02E4 | IOMMU PMU Access High 8 Register    |
| IOMMU_PMU_HIT_LOW8_REG     | 0x02E8 | IOMMU PMU Hit Low 8 Register        |
| IOMMU_PMU_HIT_HIGH8_REG    | 0x02EC | IOMMU PMU Hit High 8 Register       |
| IOMMU_PMU_TL_LOW0_REG      | 0x0300 | IOMMU Total Latency Low 0 Register  |
| IOMMU_PMU_TL_HIGH0_REG     | 0x0304 | IOMMU Total Latency High 0 Register |
| IOMMU_PMU_ML0_REG          | 0x0308 | IOMMU Max Latency 0 Register        |
| IOMMU_PMU_TL_LOW1_REG      | 0x0310 | IOMMU Total Latency Low 1 Register  |
| IOMMU_PMU_TL_HIGH1_REG     | 0x0314 | IOMMU Total Latency High 1 Register |

| Register Name          | Offset | Description                         |
|------------------------|--------|-------------------------------------|
| IOMMU_PMU_ML1_REG      | 0x0318 | IOMMU Max Latency 1 Register        |
| IOMMU_PMU_TL_LOW2_REG  | 0x0320 | IOMMU Total Latency Low 2 Register  |
| IOMMU_PMU_TL_HIGH2_REG | 0x0324 | IOMMU Total Latency High 2 Register |
| IOMMU_PMU_ML2_REG      | 0x0328 | IOMMU Max Latency 2 Register        |
| IOMMU_PMU_TL_LOW3_REG  | 0x0330 | IOMMU Total Latency Low 3 Register  |
| IOMMU_PMU_TL_HIGH3_REG | 0x0334 | IOMMU Total Latency High 3 Register |
| IOMMU_PMU_ML3_REG      | 0x0338 | IOMMU Max Latency 3 Register        |
| IOMMU_PMU_TL_LOW4_REG  | 0x0340 | IOMMU Total Latency Low 4 Register  |
| IOMMU_PMU_TL_HIGH4_REG | 0x0344 | IOMMU Total Latency High 4 Register |
| IOMMU_PMU_ML4_REG      | 0x0348 | IOMMU Max Latency 4 Register        |
| IOMMU_PMU_TL_LOW5_REG  | 0x0350 | IOMMU Total Latency Low 5 Register  |
| IOMMU_PMU_TL_HIGH5_REG | 0x0354 | IOMMU Total Latency High 5 Register |
| IOMMU_PMU_ML5_REG      | 0x0358 | IOMMU Max Latency 5 Register        |
| IOMMU_PMU_TL_LOW6_REG  | 0x0360 | IOMMU Total Latency Low 6 Register  |
| IOMMU_PMU_TL_HIGH6_REG | 0x0364 | IOMMU Total Latency High 6 Register |
| IOMMU_PMU_ML6_REG      | 0x0368 | IOMMU Max Latency 6 Register        |

## 2.9.6 Register Description

### 2.9.6.1 0x0010 IOMMU Reset Register (Default Value: 0x8003\_007F)

| Offset: 0x0010 |            |             | Register Name: IOMMU_RESET_REG                                                                                                                                                                                                                                                                                                 |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                    |
| 31             | R/W        | 0x1         | <p>IOMMU_RST<br/>IOMMU Software Reset Switch<br/>0: Set reset signal<br/>1: Release reset signal<br/>Before IOMMU software reset operation, ensure IOMMU never be opened; or all bus operations are completed; or DRAM and the peripherals have opened the corresponding switch, for shielding the effects of IOMMU reset.</p> |
| 30:18          | /          | /           | /                                                                                                                                                                                                                                                                                                                              |
| 17             | R/W        | 0x1         | <p>PC_RST<br/>PTW Cache address convert lane software reset switch.<br/>0: Set reset signal<br/>1: Release reset signal<br/>When PTW Cache occurs abnormal, this bit is used to reset PTW Cache individually.</p>                                                                                                              |
| 16             | R/W        | 0x1         | <p>MTLB_RST<br/>Macro TLB address convert lane software reset switch.<br/>0: Set reset signal</p>                                                                                                                                                                                                                              |

| Offset: 0x0010 |            |             | Register Name: IOMMU_RESET_REG                                                                                                                                                                   |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                      |
|                |            |             | 1: Release reset signal<br>When Macro TLB occurs abnormal, this bit is used to reset Macro TLB individually.                                                                                     |
| 15:7           | /          | /           | /                                                                                                                                                                                                |
| 6              | R/W        | 0x1         | M6_RST<br>Master6 address convert lane software reset switch<br>0: Set reset signal<br>1: Release reset signal<br>When Master6 occurs abnormal, this bit is used to reset Master6 individually.  |
| 5              | R/W        | 0x1         | M5_RST<br>Master5 address convert lane software reset switch.<br>0: Set reset signal<br>1: Release reset signal<br>When Master5 occurs abnormal, this bit is used to reset Master5 individually. |
| 4              | R/W        | 0x1         | M4_RST<br>Master4 address convert lane software reset switch.<br>0: Set reset signal<br>1: Release reset signal<br>When Master4 occurs abnormal, this bit is used to reset Master4 individually. |
| 3              | R/W        | 0x1         | M3_RST<br>Master3 address convert lane software reset switch.<br>0: Set reset signal<br>1: Release reset signal<br>When Master3 occurs abnormal, this bit is used to reset Master3 individually. |
| 2              | R/W        | 0x1         | M2_RST<br>Master2 address convert lane software reset switch.<br>0: Set reset signal<br>1: Release reset signal<br>When Master2 occurs abnormal, this bit is used to reset Master2 individually. |
| 1              | R/W        | 0x1         | M1_RST<br>Master1 address convert lane software reset switch.<br>0: Set reset signal<br>1: Release reset signal<br>When Master1 occurs abnormal, this bit is used to reset Master1 individually. |
| 0              | R/W        | 0x1         | M0_RST                                                                                                                                                                                           |

| Offset: 0x0010 |            |             | Register Name: IOMMU_RESET_REG                                                                                                                                                                            |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                               |
|                |            |             | <p>Master0 address convert lane software reset switch.</p> <p>0: Set reset signal</p> <p>1: Release reset signal</p> <p>When Master0 occurs abnormal, this bit is used to reset Master0 individually.</p> |

#### 2.9.6.2 0x0020 IOMMU Enable Register (Default Value: 0x0000\_0000)

| Offset: 0x0020 |            |             | Register Name: IOMMU_ENABLE_REG                                                                                                                                                                                                                                                                      |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                          |
| 31:1           | /          | /           | /                                                                                                                                                                                                                                                                                                    |
| 0              | R/W        | 0x0         | <p>I_ENABLE</p> <p>IOMMU module enable switch</p> <p>0: Disable IOMMU</p> <p>1: Enable IOMMU</p> <p>Before IOMMU address mapping function opens, configure the Translation Table Base register; or ensure all masters are in bypass status or no the status of sending bus demand(such as reset)</p> |

#### 2.9.6.3 0x0030 IOMMU Bypass Register (Default Value: 0x0000\_007f)

| Offset: 0x0030 |            |             | Register Name: IOMMU_BYPASS_REG                                                                                                                                                                                                                                             |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                 |
| 31:7           | /          | /           | /                                                                                                                                                                                                                                                                           |
| 6              | R/W        | 0x1         | <p>M6_BP</p> <p>Master6 bypass switch</p> <p>After bypass function is opened, IOMMU can not map the address of Master6 sending, and directly output the virtual address to MBUS as physical address.</p> <p>0: Disable bypass function</p> <p>1: Enable bypass function</p> |
| 5              | R/W        | 0x1         | <p>M5_BP</p> <p>Master5 bypass switch</p> <p>After bypass function is opened, IOMMU can not map the address of Master5 sending, and directly output the virtual address to MBUS as physical address.</p> <p>0: Disable bypass function</p> <p>1: Enable bypass function</p> |
| 4              | R/W        | 0x1         | M4_BP                                                                                                                                                                                                                                                                       |

| Offset: 0x0030 |            |             | Register Name: IOMMU_BYPASS_REG                                                                                                                                                                                                                                 |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                     |
|                |            |             | <p>Master4 bypass switch<br/>After bypass function is opened, IOMMU can not map the address of Master4 sending, and directly output the virtual address to MBUS as physical address.<br/>0: Disable bypass function<br/>1: Enable bypass function</p>           |
| 3              | R/W        | 0x1         | <p>M3_BP<br/>Master3 bypass switch<br/>After bypass function is opened, IOMMU can not map the address of Master3 sending, and directly output the virtual address to MBUS as physical address.<br/>0: Disable bypass function<br/>1: Enable bypass function</p> |
| 2              | R/W        | 0x1         | <p>M2_BP<br/>Master2 bypass switch<br/>After bypass function is opened, IOMMU can not map the address of Master2 sending, and directly output the virtual address to MBUS as physical address.<br/>0: Disable bypass function<br/>1: Enable bypass function</p> |
| 1              | R/W        | 0x1         | <p>M1_BP<br/>Master1 bypass switch<br/>After bypass function is opened, IOMMU can not map the address of Master1 sending, and directly output the virtual address to MBUS as physical address.<br/>0: Disable bypass function<br/>1: Enable bypass function</p> |
| 0              | R/W        | 0x1         | <p>M0_BP<br/>Master0 bypass switch<br/>After bypass function is opened, IOMMU can not map the address of Master0 sending, and directly output the virtual address to MBUS as physical address.<br/>0: Disable bypass function<br/>1: Enable bypass function</p> |



#### NOTE

- Operating the register belongs to non-accurate timing sequence control function. That is, before the function is valid, master operation will complete address mapping function, and any subsequent operation will not perform address mapping.

- It is suggested that master is in reset state or in no any bus operation before operating the register.

#### 2.9.6.4 0x0040 IOMMU Auto Gating Register (Default Value: 0x0000\_0001)

| Offset: 0x0040 |            |             | Register Name: IOMMU_AUTO_GATING_REG                                                                                                                                                       |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                |
| 31:1           | /          | /           | /                                                                                                                                                                                          |
| 0              | R/W        | 0x1         | IOMMU_AUTO_GATING<br>IOMMU circuit auto gating control<br>The purpose is to decrease power consumption of the module.<br>0: Disable auto gating function<br>1: Enable auto gating function |

#### 2.9.6.5 0x0044 IOMMU Write Buffer Control Register (Default Value: 0x0000\_007f)

| Offset: 0x0044 |            |             | Register Name: IOMMU_WBUF_CTRL_REG |
|----------------|------------|-------------|------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                        |
| 31:7           | /          | /           | /                                  |
| 6              | R/W        | 0x1         | Reserved                           |
| 5              | R/W        | 0x1         | Reserved                           |
| 4              | R/W        | 0x1         | Reserved                           |
| 3              | R/W        | 0x1         | Reserved                           |
| 2              | R/W        | 0x1         | Reserved                           |
| 1              | R/W        | 0x1         | Reserved                           |
| 0              | R/W        | 0x1         | Reserved                           |

#### 2.9.6.6 0x0048 IOMMU Out of Order Control Register (Default Value: 0x0000\_007F)

| Offset: 0x0048 |            |             | Register Name: IOMMU_OOO_CTRL_REG                                                                 |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                       |
| 31:7           | /          | /           | /                                                                                                 |
| 6              | R/W        | 0x1         | M6_OOO_CTRL.<br>Master6 Out of Order Control<br>0: Disable out-of-order<br>1: Enable out-of-order |
| 5              | R/W        | 0x1         | M5_OOO_CTRL.<br>Master5 Out of Order Control<br>0: Disable out-of-order<br>1: Enable out-of-order |
| 4              | R/W        | 0x1         | M4_OOO_CTRL.                                                                                      |

| Offset: 0x0048 |            |             | Register Name: IOMMU_OOO_CTRL_REG                                                                 |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                       |
|                |            |             | Master4 Out of Order Control<br>0: Disable out-of-order<br>1: Enable out-of-order                 |
| 3              | R/W        | 0x1         | M3_OOO_CTRL.<br>Master3 Out of Order Control<br>0: Disable out-of-order<br>1: Enable out-of-order |
| 2              | R/W        | 0x1         | M2_OOO_CTRL.<br>Master2 Out of Order Control<br>0: Disable out-of-order<br>1: Enable out-of-order |
| 1              | R/W        | 0x1         | M1_OOO_CTRL.<br>Master1 Out of Order Control<br>0: Disable out-of-order<br>1: Enable out-of-order |
| 0              | R/W        | 0x1         | M0_OOO_CTRL.<br>Master0 Out of Order Control<br>0: Disable out-of-order<br>1: Enable out-of-order |

#### 2.9.6.7 0x004C IOMMU 4KB Boundary Protect Control Register (Default Value: 0x0000\_007F)



##### NOTE

When the virtual address sent by master is over the 4 KB boundary, 4 KB protection unit will split it into two serial access.

| Offset: 0x004C |            |             | Register Name: IOMMU_4KB_BDY_PRT_CTRL_REG                                                                                               |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                             |
| 31:7           | /          | /           | /                                                                                                                                       |
| 6              | R/W        | 0x1         | M6_4KB_BDY_PRT_CTRL<br>Master6 4 KB boundary protect control bit<br>0: Disable 4 KB boundary protect<br>1: Enable 4 KB boundary protect |
| 5              | R/W        | 0x1         | M5_4KB_BDY_PRT_CTRL<br>Master4 4 KB boundary protect control bit<br>0: Disable 4 KB boundary protect<br>1: Enable 4 KB boundary protect |
| 4              | R/W        | 0x1         | M4_4KB_BDY_PRT_CTRL<br>Master4 4 KB boundary protect control bit                                                                        |

| Offset: 0x004C |            |             | Register Name: IOMMU_4KB_BDY_PRT_CTRL_REG                                                                                               |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                             |
|                |            |             | 0: Disable 4 KB boundary protect<br>1: Enable 4 KB boundary protect                                                                     |
| 3              | R/W        | 0x1         | M3_4KB_BDY_PRT_CTRL<br>Master3 4 KB boundary protect control bit<br>0: Disable 4 KB boundary protect<br>1: Enable 4 KB boundary protect |
| 2              | R/W        | 0x1         | M2_4KB_BDY_PRT_CTRL<br>Master2 4 KB boundary protect control bit<br>0: Disable 4 KB boundary protect<br>1: Enable 4 KB boundary protect |
| 1              | R/W        | 0x1         | M1_4KB_BDY_PRT_CTRL<br>Master1 4 KB boundary protect control bit<br>0: Disable 4 KB boundary protect<br>1: Enable 4 KB boundary protect |
| 0              | R/W        | 0x1         | M0_4KB_BDY_PRT_CTRL<br>Master0 4 KB boundary protect control bit<br>0: Disable 4 KB boundary protect<br>1: Enable 4 KB boundary protect |

#### 2.9.6.8 0x0050 IOMMU Translation Table Base Register (Default Value: 0x0000\_0000)

| Offset: 0x0050 |            |             | Register Name: IOMMU_TTB_REG                                                                                                                                                                                                                                                                                             |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                              |
| 31:14          | R/W        | 0x0         | TTB<br>Translation Table Base<br>Level1 page table starting address, aligned to 16 KB.<br>When operating the register, IOMMU address mapping function must be closed, namely IOMMU_ENABLE_REG is 0;<br>Or Bypass function of all main equipment is set to 1, or no the state of transfer bus commands (such as setting). |
| 13:0           | /          | /           | /                                                                                                                                                                                                                                                                                                                        |

#### 2.9.6.9 0x0060 IOMMU TLB Enable Register (Default Value: 0x0003\_007F)

| Offset: 0x0060 |            |             | Register Name: IOMMU_TLB_ENABLE_REG     |
|----------------|------------|-------------|-----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                             |
| 31:18          | /          | /           | /                                       |
| 17             | R/W        | 0x1         | PC_EN<br>PTW Cache Enable<br>0: Disable |

| Offset: 0x0060 |            |             | Register Name: IOMMU_TLB_ENABLE_REG                                     |
|----------------|------------|-------------|-------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                             |
|                |            |             | 1: Enable                                                               |
| 16             | R/W        | 0x1         | MICRO_TLB_ENABLE<br>Micro TLB enable bit<br>0: Disable<br>1: Enable     |
| 15:7           | /          | /           | /                                                                       |
| 6              | R/W        | 0x1         | MICRO_TLB6_ENABLE<br>Micro TLB6 enable bit<br>0: Disable<br>1: Enable   |
| 5              | R/W        | 0x1         | MICRO_TLB5_ENABLE<br>Micro TLB5 enable bit<br>0: Disable<br>1: Enable   |
| 4              | R/W        | 0x1         | MICRO_TLB4_ENABLE<br>Micro TLB4 enable bit<br>0: Disable<br>1: Enable   |
| 3              | R/W        | 0x1         | MICRO_TLB3_ENABLE<br>Micro TLB3 enable bit<br>0: Disable<br>1: Enable   |
| 2              | R/W        | 0x1         | MICRO_TLB2_ENABLE<br>Micro TLB2 enable bit<br>0: Disable<br>1: Enable   |
| 1              | R/W        | 0x1         | MICRO1_TLB0_ENABLE<br>Micro TLB01 enable bit<br>0: Disable<br>1: Enable |
| 0              | R/W        | 0x1         | MACRO0_TLB_ENABLE<br>Macro TLB0 enable bit<br>0: Disable<br>1: Enable   |

#### 2.9.6.10 0x0070 IOMMU TLB PreFetch Register (Default Value: 0x0003\_0000)

| Offset: 0x0070 |            |             | Register Name: IOMMU_TLB_PREFETCH_REG |
|----------------|------------|-------------|---------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                           |
| 31:18          | /          | /           | /                                     |

| Offset: 0x0070 |            |             | Register Name: IOMMU_TLB_PREFETCH_REG                                                                                                                                                                           |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                     |
| 17             | R/W        | 0x1         | <p>PF_VL_PT_TO_PC<br/>Prefetch Value Page Table to PTW Cache<br/>0: Disable<br/>1: Enable<br/>If the function is enabled, the prefetch function will not update the invalid Level1 page table to PTW cache.</p> |
| 16             | R/W        | 0x1         | <p>PF_VL_PT_TO_MT<br/>Prefetch Value Page Table to Macro TLB<br/>0: Disable<br/>1: Enable<br/>If the function is enabled, the prefetch function will not update the invalid Level2 page table to Macro TLB.</p> |
| 15:7           | /          | /           | /                                                                                                                                                                                                               |
| 6              | R/W        | 0x0         | <p>MI_TLB6_PF<br/>Micro TLB6 Prefetch Enable<br/>0: Disable<br/>1: Enable</p>                                                                                                                                   |
| 5              | R/W        | 0x0         | <p>MI_TLB5_PF<br/>Micro TLB5 Prefetch Enable<br/>0: Disable<br/>1: Enable</p>                                                                                                                                   |
| 4              | R/W        | 0x0         | <p>MI_TLB4_PF<br/>Micro TLB4 Prefetch Enable<br/>0: Disable<br/>1: Enable</p>                                                                                                                                   |
| 3              | R/W        | 0x0         | <p>MI_TLB3_PF<br/>Micro TLB3 Prefetch Enable<br/>0: Disable<br/>1: Enable<br/>If G2D accesses DDR, it is suggested to disable the prefetch function.</p>                                                        |
| 2              | R/W        | 0x0         | <p>MI_TLB2_PF<br/>Micro TLB2 Prefetch Enable<br/>0: Disable<br/>1: Enable</p>                                                                                                                                   |
| 1              | R/W        | 0x0         | <p>MI_TLB1_PF<br/>Micro TLB1 Prefetch Enable<br/>0: Disable<br/>1: Enable</p>                                                                                                                                   |
| 0              | R/W        | 0x0         | <p>MI_TLB0_PF<br/>Micro TLB0 Prefetch Enable</p>                                                                                                                                                                |

| Offset: 0x0070 |            |             | Register Name: IOMMU_TLB_PREFETCH_REG |
|----------------|------------|-------------|---------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                           |
|                |            |             | 0: Disable<br>1: Enable               |

#### 2.9.6.11 0x0080 IOMMU TLB Flush Enable Register (Default Value: 0x0000\_0000)

When performing flush operations, all TLB/Cache access will be paused.

Before flush starts, the operation that has entered will continue until it finishes.

| Offset: 0x0080 |            |             | Register Name: IOMMU_TLB_FLUSH_ENABLE_REG                                                                                                                                                                                 |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                               |
| 31:18          | /          | /           | /                                                                                                                                                                                                                         |
| 17             | R/WAC      | 0x0         | PC_FS<br>PTW Cache Flush<br>Clear PTW Cache<br>0: No clear operation or clear operation is completed<br>1: Enable clear operation<br>After the Flush operation is completed, the bit can be cleared automatically.        |
| 16             | R/WAC      | 0x0         | MA_TLB_FS<br>Macro TLB Flush<br>Clear Macro TLB<br>0: No clear operation or clear operation is completed<br>1: Enable clear operation<br>After the Flush operation is completed, the bit can be cleared automatically.    |
| 15:7           | /          | /           | /                                                                                                                                                                                                                         |
| 6              | R/WAC      | 0x0         | MI_TLB6_FS<br>Micro TLB6 Flush<br>Clear Micro TLB6<br>0: No clear operation or clear operation is completed<br>1: Enable clear operation<br>After the Flush operation is completed, the bit can be cleared automatically. |
| 5              | R/WAC      | 0x0         | MI_TLB5_FS<br>Micro TLB5 Flush<br>Clear Micro TLB5<br>0: No clear operation or clear operation is completed<br>1: Enable clear operation<br>After the Flush operation is completed, the bit can be cleared automatically. |
| 4              | R/WAC      | 0x0         | MI_TLB4_FS                                                                                                                                                                                                                |

| Offset: 0x0080 |            |             | Register Name: IOMMU_TLB_FLUSH_ENABLE_REG                                                                                                                                                                                 |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                               |
|                |            |             | Micro TLB4 Flush<br>Clear Micro TLB4<br>0: No clear operation or clear operation is completed<br>1: Enable clear operation<br>After the Flush operation is completed, the bit can be cleared automatically.               |
| 3              | R/WAC      | 0x0         | MI_TLB3_FS<br>Micro TLB3 Flush<br>Clear Micro TLB3<br>0: No clear operation or clear operation is completed<br>1: Enable clear operation<br>After the Flush operation is completed, the bit can be cleared automatically. |
| 2              | R/WAC      | 0x0         | MI_TLB2_FS<br>Micro TLB2 Flush<br>Clear Micro TLB2<br>0: No clear operation or clear operation is completed<br>1: Enable clear operation<br>After the Flush operation is completed, the bit can be cleared automatically. |
| 1              | R/WAC      | 0x0         | MI_TLB1_FS<br>Micro TLB1 Flush<br>Clear Micro TLB1<br>0: No clear operation or clear operation is completed<br>1: Enable clear operation<br>After the Flush operation is completed, the bit can be cleared automatically. |
| 0              | R/WAC      | 0x0         | MI_TLB0_FS<br>Micro TLB0 Flush<br>Clear Micro TLB0<br>0: No clear operation or clear operation is completed<br>1: Enable clear operation<br>After the Flush operation is completed, the bit can be cleared automatically. |

#### 2.9.6.12 0x0084 IOMMU TLB Invalidation Mode Select Register (Default Value: 0x0000\_0000)

| Offset: 0x0084 |            |             | Register Name: IOMMU_TLB_IVLD_MODE_SEL_REG |
|----------------|------------|-------------|--------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                |
| 31:1           | /          | /           | /                                          |
| 0              | R/W        | 0x0         | TLB_IVLD_MODE_SEL                          |

| Offset: 0x0084 |            |             | Register Name: IOMMU_TLB_IVLD_MODE_SEL_REG                                                    |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                   |
|                |            |             | 0: Invalidate TLB by using the Mask mode<br>1: Invalidate TLB by using the Start and End mode |

#### 2.9.6.13 0x0088 IOMMU TLB Invalid Start Address Register (Default Value: 0x0000\_0000)

| Offset: 0x0088 |            |             | Register Name: IOMMU_TLB_IVLD_STA_ADDR_REG                                           |
|----------------|------------|-------------|--------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                          |
| 31:12          | R/W        | 0x0         | TLB_IVLD_SA<br>TLB Invalid Start Address<br>TLB invalid start address, 4 KB aligned. |
| 11:0           | /          | /           | /                                                                                    |

#### 2.9.6.14 0x008C IOMMU TLB Invalid End Address Register (Default Value: 0x0000\_0000)

| Offset: 0x008C |            |             | Register Name: IOMMU_TLB_IVLD_END_ADDR_REG                                       |
|----------------|------------|-------------|----------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                      |
| 31:12          | R/W        | 0x0         | TLB_IVLD_EA<br>TLB Invalid End Address<br>TLB invalid end address, 4 KB aligned. |
| 11:0           | /          | /           | /                                                                                |

#### 2.9.6.15 0x0090 IOMMU TLB Invalid Address Register (Default Value: 0x0000\_0000)

| Offset: 0x0090 |            |             | Register Name: IOMMU_TLB_IVLD_ADDR_REG                                    |
|----------------|------------|-------------|---------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                               |
| 31:12          | R/W        | 0x0         | TLB_IVLD_ADDR<br>TLB Invalid Address<br>TLB invalid address, 4 KB aligned |
| 11:0           | /          | /           | /                                                                         |

##### Operation:

- Set the virtual address that needs to be operated in IOMMU\_TLB\_IVLD\_ADDR\_REG.
- Set the mask of virtual address that needs to be operated in [IOMMU\\_TLB\\_IVLD\\_ADDR\\_MASK\\_REG](#).
- Write '1' to [IOMMU\\_TLB\\_IVLD\\_ENABLE\\_REG](#) [0].
- Read [IOMMU\\_TLB\\_IVLD\\_ENABLE\\_REG](#) [0], when it is '0', it indicates that invalidation behavior is finished.



## NOTE

- When performing invalidation operation, TLB/Cache operation has not affected.
- After or before invalidation operation starts, there is no absolute relationship between the same address switch operation and invalidation operation.

## 2.9.6.16 0x0094 IOMMU TLB Invalid Address Mask Register (Default Value: 0x0000\_0000)

| Offset: 0x0094 |            |             | Register Name: IOMMU_TLB_IVLD_ADDR_MASK_REG                                                       |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                       |
| 31:12          | R/W        | 0x0         | TLB_IVLD_ADDR_MASK<br>TLB Invalid Address Mask<br>TLB invalid address mask register, 4 KB aligned |
| 11:0           | /          | /           | /                                                                                                 |

## 2.9.6.17 0x0098 IOMMU TLB Invalid Enable Register (Default Value: 0x0000\_0000)

| Offset: 0x0098 |            |             | Register Name: IOMMU_TLB_IVLD_ENABLE_REG                                                                                                                                                                                                                                                                                                                                                                                                                        |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 31:1           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 0              | R/WAC      | 0x0         | TLB_IVLD_ENABLE.<br>Enable TLB invalidation operation<br>0: No operation or operation is completed<br>1: Enable invalidation operation<br>After invalidation operation is completed, the bit can clear automatically.<br>When operating invalidation operation, TLB/Cache operation has not affected.<br>After or before invalidation operation starts, there is no absolute relationship between the same address switch operation and invalidation operation. |

## 2.9.6.18 0x009C IOMMU PC Invalid Mode Select Register (Default Value: 0x0000\_0000)

| Offset: 0x009C |            |             | Register Name: IOMMU_PC_IVLD_MODE_SEL_REG                                                 |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                               |
| 31:1           | /          | /           | /                                                                                         |
| 0              | R/W        | 0x0         | PC_IVLD_MS.<br>PTW Cache Invalid Mode Select.<br>0: Invalidate PTW by using the Mask mode |

| Offset: 0x009C |            |             | Register Name: IOMMU_PC_IVLD_MODE_SEL_REG         |
|----------------|------------|-------------|---------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                       |
|                |            |             | 1: Invalidate PTW by using the Start and End mode |

#### 2.9.6.19 0x00A0 IOMMU PC Invalid Address Register (Default Value: 0x0000\_0000)

| Offset: 0x00A0 |            |             | Register Name: IOMMU_PC_IVLD_ADDR_REG                     |
|----------------|------------|-------------|-----------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                               |
| 31:20          | R/W        | 0x0         | PC_IVLD_ADDR.<br>PTW Cache Invalid Address, 1 MB aligned. |
| 19:0           | /          | /           | /                                                         |

#### 2.9.6.20 0x00A4 IOMMU PC Invalid Start Address Register (Default Value: 0x0000\_0000)

| Offset: 0x00A4 |            |             | Register Name: IOMMU_PC_IVLD_STA_ADDR_REG                   |
|----------------|------------|-------------|-------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                 |
| 31:20          | R/W        | 0x0         | PC_IVLD_SA.<br>PTW Cache Invalid Start Address, 1M aligned. |
| 19:0           | /          | /           | /                                                           |

#### 2.9.6.21 0x00A8 IOMMU PC Invalid Enable Register (Default Value: 0x0000\_0000)

| Offset: 0x00A8 |            |             | Register Name: IOMMU_PC_IVLD_ENABLE_REG |
|----------------|------------|-------------|-----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                             |
| 31:1           | /          | /           | /                                       |

  

|   |       |     |                                                                                                                                                                                                                                       |
|---|-------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 | R/WAC | 0x0 | PC_IVLD_EN.<br>Enable PTW Cache invalidation operation<br>0: No operation or operation is completed<br>1: Enable invalidation operation                                                                                               |
|   |       |     | After invalidation operation is completed, the bit can clear automatically.<br>After or before invalidation operation starts, there is no absolute relationship between the same address switch operation and invalidation operation. |

#### 2.9.6.22 0x00AC IOMMU PC Invalid End Address Register (Default Value: 0x0000\_0000)

| Offset: 0x00AC |            |             | Register Name: IOMMU_PC_IVLD_END_ADDR_REG                   |
|----------------|------------|-------------|-------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                 |
| 31:20          | R/W        | 0x0         | PC_IVLD_EA.<br>PTW Cache invalid end address, 1 MB aligned. |

| Offset: 0x00AC |            |             | Register Name: IOMMU_PC_IVLD_END_ADDR_REG |
|----------------|------------|-------------|-------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                               |
| 19:0           | /          | /           | /                                         |

### 2.9.6.23 0x0100 IOMMU Interrupt Enable Register (Default Value: 0x0000\_0000)

Invalid page table and permission error can not make one device or multi-devices in system work normally.

Permission error usually happens in MicroTLB. The error generates interrupt and waits for processing through software.

Invalid page table usually happens in Macro TLB. The error can not influence the access of other devices. So the error page table needs go back the way it comes, but the error should not be written in each level TLB.

| Offset: 0x0100 |            |             | Register Name: IOMMU_INT_ENABLE_REG                                                                                                   |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                           |
| 31:21          | /          | /           | /                                                                                                                                     |
| 20             | R/W        | 0x0         | DBG_PF_L2_IV_PT_EN.<br>Debug or Prefetch Invalid Page Table Enable<br>0: Mask interrupt<br>1: Enable interrupt                        |
| 19             | R/W        | 0x0         | DBG_PF_PC_IV_L1_PT_EN.<br>Debug or Prefetch PTW Cache Invalid Level1 Page Table<br>Enable<br>0: Mask interrupt<br>1: Enable interrupt |
| 18             | R/W        | 0x0         | DBG_PF_DRAM_IV_L1_PT_EN.<br>Debug or Prefetch DRAM Invalid Level1 Page Table Enable<br>0: Mask interrupt<br>1: Enable interrupt       |
| 17             | R/W        | 0x0         | L2_PAGE_TABLE_INVALID_EN<br>Level2 page table invalid interrupt enable<br>0: Mask interrupt<br>1: Enable interrupt                    |
| 16             | R/W        | 0x0         | L1_PAGE_TABLE_INVALID_EN<br>Level1 page table invalid interrupt enable<br>0: Mask interrupt<br>1: Enable interrupt                    |
| 15:7           | /          | /           | /                                                                                                                                     |
| 6              | R/W        | 0x0         | MICRO_TLB6_INVALID_EN<br>Micro TLB6 permission invalid interrupt enable<br>0: Mask interrupt<br>1: Enable interrupt                   |

| Offset: 0x0100 |            |             | Register Name: IOMMU_INT_ENABLE_REG                                                                                 |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                         |
| 5              | R/W        | 0x0         | MICRO_TLB5_INVALID_EN<br>Micro TLB5 permission invalid interrupt enable<br>0: Mask interrupt<br>1: Enable interrupt |
| 4              | R/W        | 0x0         | MICRO_TLB4_INVALID_EN<br>Micro TLB4 permission invalid interrupt enable<br>0: Mask interrupt<br>1: Enable interrupt |
| 3              | R/W        | 0x0         | MICRO_TLB3_INVALID_EN<br>Micro TLB3 permission invalid interrupt enable<br>0: Mask interrupt<br>1: Enable interrupt |
| 2              | R/W        | 0x0         | MICRO_TLB2_INVALID_EN<br>Micro TLB2 permission invalid interrupt enable<br>0: Mask interrupt<br>1: Enable interrupt |
| 1              | R/W        | 0x0         | MICRO_TLB1_INVALID_EN<br>Micro TLB1 permission invalid interrupt enable<br>0: Mask interrupt<br>1: Enable interrupt |
| 0              | R/W        | 0x0         | MICRO_TLB0_INVALID_EN<br>Micro TLB0 permission invalid interrupt enable<br>0: Mask interrupt<br>1: Enable interrupt |

#### 2.9.6.24 0x0104 IOMMU Interrupt Clear Register (Default Value: 0x0000\_0000)

| Offset: 0x0104 |            |             | Register Name: IOMMU_INT_CLR_REG                                                                                         |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                              |
| 31:18          | /          | /           | /                                                                                                                        |
| 17             | W          | 0x0         | L2_PAGE_TABLE_INVALID_CLR<br>Level2 page table invalid interrupt clear bit<br>0: Invalid operation<br>1: Clear interrupt |
| 16             | W          | 0x0         | L1_PAGE_TABLE_INVALID_CLR<br>Level1 page table invalid interrupt clear bit<br>0: Invalid operation<br>1: Clear interrupt |
| 15:7           | /          | /           | /                                                                                                                        |
| 6              | W          | 0x0         | MICRO_TLB6_INVALID_CLR<br>Micro TLB6 permission invalid interrupt clear bit                                              |

| Offset: 0x0104 |            |             | Register Name: IOMMU_INT_CLR_REG                                                                                          |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                               |
|                |            |             | 0: Invalid operation<br>1: Clear interrupt<br><b>Note: The bit is not used.</b>                                           |
| 5              | W          | 0x0         | MICRO_TLB5_INVALID_CLR<br>Micro TLB5 permission invalid interrupt clear bit<br>0: Invalid operation<br>1: Clear interrupt |
| 4              | W          | 0x0         | MICRO_TLB4_INVALID_CLR<br>Micro TLB4 permission invalid interrupt clear bit<br>0: Invalid operation<br>1: Clear interrupt |
| 3              | W          | 0x0         | MICRO_TLB3_INVALID_CLR<br>Micro TLB3 permission invalid interrupt clear bit<br>0: Invalid operation<br>1: Clear interrupt |
| 2              | W          | 0x0         | MICRO_TLB2_INVALID_CLR<br>Micro TLB2 permission invalid interrupt clear bit<br>0: Invalid operation<br>1: Clear interrupt |
| 1              | W          | 0x0         | MICRO_TLB1_INVALID_CLR<br>Micro TLB1 permission invalid interrupt clear bit<br>0: Invalid operation<br>1: Clear interrupt |
| 0              | W          | 0x0         | MICRO_TLB0_INVALID_CLR<br>Micro TLB0 permission invalid interrupt clear bit<br>0: Invalid operation<br>1: Clear interrupt |

#### 2.9.6.25 0x0108 IOMMU Interrupt Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0108 |            |             | Register Name: IOMMU_INT_STA_REG                                                                                                                            |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                 |
| 31:18          | /          | /           | /                                                                                                                                                           |
| 17             | R          | 0x0         | L2_PAGE_TABLE_INVALID_STA<br>Level2 page table invalid interrupt status bit<br>0: Interrupt does not happen or interrupt is cleared<br>1: Interrupt happens |
| 16             | R          | 0x0         | L1_PAGE_TABLE_INVALID_STA<br>Level1 page table invalid interrupt status bit<br>0: Interrupt does not happen or interrupt is cleared<br>1: Interrupt happens |

| Offset: 0x0108 |            |             | Register Name: IOMMU_INT_STA_REG                                                                                                                                                                  |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                       |
| 15:7           | /          | /           | /                                                                                                                                                                                                 |
| 6              | R          | 0x0         | MICRO_TLB6_INVALID_STA<br>Micro TLB6 permission invalid interrupt status bit<br>0: Interrupt does not happen or interrupt is cleared<br>1: Interrupt happens<br><b>Note: The bit is not used.</b> |
| 5              | R          | 0x0         | MICRO_TLB5_INVALID_STA<br>Micro TLB5 permission invalid interrupt status bit<br>0: Interrupt does not happen or interrupt is cleared<br>1: Interrupt happens                                      |
| 4              | R          | 0x0         | MICRO_TLB4_INVALID_STA<br>Micro TLB4 permission invalid interrupt status bit<br>0: Interrupt does not happen or interrupt is cleared<br>1: Interrupt happens                                      |
| 3              | R          | 0x0         | MICRO_TLB3_INVALID_STA<br>Micro TLB3 permission invalid interrupt status bit<br>0: Interrupt does not happen or interrupt is cleared<br>1: Interrupt happens                                      |
| 2              | R          | 0x0         | MICRO_TLB2_INVALID_STA<br>Micro TLB2 permission invalid interrupt status bit<br>0: Interrupt does not happen or interrupt is cleared<br>1: Interrupt happens                                      |
| 1              | R          | 0x0         | MICRO_TLB1_INVALID_STA<br>Micro TLB1 permission invalid interrupt status bit<br>0: Interrupt does not happen or interrupt is cleared<br>1: Interrupt happens                                      |
| 0              | R          | 0x0         | MICRO_TLB0_INVALID_STA<br>Micro TLB0 permission invalid interrupt status bit<br>0: Interrupt does not happen or interrupt is cleared<br>1: Interrupt happens                                      |

#### 2.9.6.26 0x0110 IOMMU Interrupt Error Address 0 Register (Default Value: 0x0000\_0000)

| Offset: 0x0110 |            |             | Register Name: IOMMU_INT_ERR_ADDR0_REG                                                             |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                        |
| 31:0           | R          | 0x0         | INT_ERR_ADDR0.<br>Interrupt Error Address0.<br>Virtual address that caused Micro TLB0 to interrupt |

**2.9.6.27 0x0114 IOMMU Interrupt Error Address 1 Register (Default Value: 0x0000\_0000)**

| Offset: 0x0114 |            |             | Register Name: IOMMU_INT_ERR_ADDR1_REG                                                             |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                        |
| 31:0           | R          | 0x0         | INT_ERR_ADDR1.<br>Interrupt Error Address1.<br>Virtual address that caused Micro TLB1 to interrupt |

**2.9.6.28 0x0118 IOMMU Interrupt Error Address 2 Register (Default Value: 0x0000\_0000)**

| Offset: 0x0118 |            |             | Register Name: IOMMU_INT_ERR_ADDR2_REG                                                             |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                        |
| 31:0           | R          | 0x0         | INT_ERR_ADDR2.<br>Interrupt Error Address2.<br>Virtual address that caused Micro TLB2 to interrupt |

**2.9.6.29 0x011C IOMMU Interrupt Error Address 3 Register (Default Value: 0x0000\_0000)**

| Offset: 0x011C |            |             | Register Name: IOMMU_INT_ERR_ADDR3_REG                                                             |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                        |
| 31:0           | R          | 0x0         | INT_ERR_ADDR3.<br>Interrupt Error Address3.<br>Virtual address that caused Micro TLB3 to interrupt |

**2.9.6.30 0x0120 IOMMU Interrupt Error Address 4 Register (Default Value: 0x0000\_0000)**

| Offset: 0x0120 |            |             | Register Name: IOMMU_INT_ERR_ADDR4_REG                                                             |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                        |
| 31:0           | R          | 0x0         | INT_ERR_ADDR4.<br>Interrupt Error Address4.<br>Virtual address that caused Micro TLB4 to interrupt |

**2.9.6.31 0x0124 IOMMU Interrupt Error Address 5 Register (Default Value: 0x0000\_0000)**

| Offset: 0x0124 |            |             | Register Name: IOMMU_INT_ERR_ADDR5_REG                                                             |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                        |
| 31:0           | R          | 0x0         | INT_ERR_ADDR5.<br>Interrupt Error Address5.<br>Virtual address that caused Micro TLB5 to interrupt |

#### 2.9.6.32 0x0128 IOMMU Interrupt Error Address 6 Register (Default Value: 0x0000\_0000)

| Offset: 0x0128 |            |             | Register Name: IOMMU_INT_ERR_ADDR6_REG                                                             |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                        |
| 31:0           | R          | 0x0         | INT_ERR_ADDR6.<br>Interrupt Error Address6.<br>Virtual address that caused Micro TLB6 to interrupt |

#### 2.9.6.33 0x0130 IOMMU Interrupt Error Address 7 Register (Default Value: 0x0000\_0000)

| Offset: 0x0130 |            |             | Register Name: IOMMU_INT_ERR_ADDR7_REG                                                                |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                           |
| 31:0           | R          | 0x0         | INT_ERR_ADDR7.<br>Interrupt Error Address7.<br>Virtual address that caused L1 page table to interrupt |

#### 2.9.6.34 0x0134 IOMMU Interrupt Error Address 8 Register (Default Value: 0x0000\_0000)

| Offset: 0x0134 |            |             | Register Name: IOMMU_INT_ERR_ADDR8_REG                                                                |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                           |
| 31:0           | R          | 0x0         | INT_ERR_ADDR8.<br>Interrupt Error Address8.<br>Virtual address that caused L2 page table to interrupt |

#### 2.9.6.35 0x0150 IOMMU Interrupt Error Data 0 Register (Default Value: 0x0000\_0000)

| Offset: 0x0150 |            |             | Register Name: IOMMU_INT_ERR_DATA0_REG                                                                                      |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                 |
| 31:0           | R          | 0x0         | INT_ERR_DATA0.<br>Interrupt Error Data0.<br>Corresponding page table of virtual address that caused Micro TLB0 to interrupt |

#### 2.9.6.36 0x0154 IOMMU Interrupt Error Data 1 Register (Default Value: 0x0000\_0000)

| Offset: 0x0154 |            |             | Register Name: IOMMU_INT_ERR_DATA1_REG                                                                                      |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                 |
| 31:0           | R          | 0x0         | INT_ERR_DATA1.<br>Interrupt Error Data1.<br>Corresponding page table of virtual address that caused Micro TLB1 to interrupt |

### 2.9.6.37 0x0158 IOMMU Interrupt Error Data 2 Register (Default Value: 0x0000\_0000)

| Offset: 0x0158 |            |             | Register Name: IOMMU_INT_ERR_DATA2_REG                                                                                      |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                 |
| 31:0           | R          | 0x0         | INT_ERR_DATA2.<br>Interrupt Error Data2.<br>Corresponding page table of virtual address that caused Micro TLB2 to interrupt |

### 2.9.6.38 0x015C IOMMU Interrupt Error Data 3 Register (Default Value: 0x0000\_0000)

| Offset: 0x015C |            |             | Register Name: IOMMU_INT_ERR_DATA3_REG                                                                                      |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                 |
| 31:0           | R          | 0x0         | INT_ERR_DATA3.<br>Interrupt Error Data3.<br>Corresponding page table of virtual address that caused Micro TLB3 to interrupt |

### 2.9.6.39 0x0160 IOMMU Interrupt Error Data 4 Register (Default Value: 0x0000\_0000)

| Offset: 0x0160 |            |             | Register Name: IOMMU_INT_ERR_DATA4_REG                                                                                      |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                 |
| 31:0           | R          | 0x0         | INT_ERR_DATA4.<br>Interrupt Error Data4.<br>Corresponding page table of virtual address that caused Micro TLB4 to interrupt |

### 2.9.6.40 0x0164 IOMMU Interrupt Error Data 5 Register (Default Value: 0x0000\_0000)

| Offset: 0x0164 |            |             | Register Name: IOMMU_INT_ERR_DATA5_REG                                                                                      |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                 |
| 31:0           | R          | 0x0         | INT_ERR_DATA5.<br>Interrupt Error Data5.<br>Corresponding page table of virtual address that caused Micro TLB5 to interrupt |

### 2.9.6.41 0x0168 IOMMU Interrupt Error Data 6 Register (Default Value: 0x0000\_0000)

| Offset: 0x0168 |            |             | Register Name: IOMMU_INT_ERR_DATA6_REG |
|----------------|------------|-------------|----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                            |
| 31:0           | R          | 0x0         | INT_ERR_DATA6.                         |

| Offset: 0x0168 |            |             | Register Name: IOMMU_INT_ERR_DATA6_REG                                                                    |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                               |
|                |            |             | Interrupt Error Data6.<br>Corresponding page table of virtual address that caused Micro TLB6 to interrupt |

#### 2.9.6.42 0x0170 IOMMU Interrupt Error Data 7 Register (Default Value: 0x0000\_0000)

| Offset: 0x0170 |            |             | Register Name: IOMMU_INT_ERR_DATA7_REG                                                                                         |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                    |
| 31:0           | R          | 0x0         | INT_ERR_DATA7.<br>Interrupt Error Data7.<br>Corresponding page table of virtual address that caused L1 page table to interrupt |

#### 2.9.6.43 0x0174 IOMMU Interrupt Error Data 8 Register (Default Value: 0x0000\_0000)

| Offset: 0x0174 |            |             | Register Name: IOMMU_INT_ERR_DATA8_REG                                                                                         |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                    |
| 31:0           | R          | 0x0         | INT_ERR_DATA8.<br>Interrupt Error Data8.<br>Corresponding page table of virtual address that caused L2 page table to interrupt |

#### 2.9.6.44 0x0180 IOMMU L1 Page Table Interrupt Register (Default Value: 0x0000\_0000)

| Offset: 0x0180 |            |             | Register Name: IOMMU_L1PG_INT_REG                                                       |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                             |
| 31             | R          | 0x0         | DBG_MODE_L1PG_INT<br>Debug mode address switch causes L1 page table to occur interrupt. |
| 30:7           | /          | /           | /                                                                                       |
| 6              | R          | 0x0         | MASTER6_L1PG_INT<br>Master6 address switch causes L1 page table to occur interrupt.     |
| 5              | R          | 0x0         | MASTER5_L1PG_INT<br>Master5 address switch causes L1 page table to occur interrupt.     |
| 4              | R          | 0x0         | MASTER4_L1PG_INT<br>Master4 address switch causes L1 page table to occur interrupt.     |

| Offset: 0x0180 |            |             | Register Name: IOMMU_L1PG_INT_REG                                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                         |
| 3              | R          | 0x0         | MASTER3_L1PG_INT<br>Master3 address switch causes L1 page table to occur interrupt. |
| 2              | R          | 0x0         | MASTER2_L1PG_INT<br>Master2 address switch causes L1 page table to occur interrupt. |
| 1              | R          | 0x0         | MASTER1_L1PG_INT<br>Master1 address switch causes L1 page table to occur interrupt. |
| 0              | R          | 0x0         | MASTER0_L1PG_INT<br>Master0 address switch causes L1 page table to occur interrupt. |

#### 2.9.6.45 0x0184 IOMMU L2 Page Table Interrupt Register (Default Value: 0x0000\_0000)

| Offset: 0x0184 |            |             | Register Name: IOMMU_L2PG_INT_REG                                                                                        |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                              |
| 31             | R          | 0x0         | DBG_MODE_L2PG_INT<br>Debug mode address switch causes L2 page table to occur interrupt.                                  |
| 30:7           | /          | /           | /                                                                                                                        |
| 6              | R          | 0x0         | MASTER6_L2PG_INT<br>Master6 address switch causes L2 page table to occur interrupt.<br><b>Note: The bit is not used.</b> |
| 5              | R          | 0x0         | MASTER5_L2PG_INT<br>Master5 address switch causes L2 page table to occur interrupt.                                      |
| 4              | R          | 0x0         | MASTER4_L2PG_INT<br>Master4 address switch causes L2 page table to occur interrupt.                                      |
| 3              | R          | 0x0         | MASTER3_L2PG_INT<br>Master3 address switch causes L2 page table to occur interrupt.                                      |
| 2              | R          | 0x0         | MASTER2_L2PG_INT<br>Master2 address switch causes L2 page table to occur interrupt.                                      |
| 1              | R          | 0x0         | MASTER1_L2PG_INT<br>Master1 address switch causes L2 page table to occur interrupt.                                      |

| Offset: 0x0184 |            |             | Register Name: IOMMU_L2PG_INT_REG                                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                         |
| 0              | R          | 0x0         | MASTER0_L2PG_INT<br>Master0 address switch causes L2 page table to occur interrupt. |

#### 2.9.6.46 0x0190 IOMMU Virtual Address Register (Default Value: 0x0000\_0000)

| Offset: 0x0190 |            |             | Register Name: IOMMU_VA_REG         |
|----------------|------------|-------------|-------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                         |
| 31:0           | R/W        | 0x0         | VA<br>Virtual address of read/write |

#### 2.9.6.47 0x0194 IOMMU Virtual Address Data Register (Default Value: 0x0000\_0000)

| Offset: 0x0194 |            |             | Register Name: IOMMU_VA_DATA_REG                            |
|----------------|------------|-------------|-------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                 |
| 31:0           | R/W        | 0x0         | VA_DATA<br>Data corresponding to read/write virtual address |

#### 2.9.6.48 0x0198 IOMMU Virtual Address Configuration Register (Default Value: 0x0000\_0000)

| Offset: 0x0198 |            |             | Register Name: IOMMU_VA_CONFIG_REG                                                                                                             |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                    |
| 31             | R/W        | 0x0         | MODE_SEL<br>0: Prefetch<br>1: Debug Mode<br>It is used to choose prefetch mode or Debug mode.                                                  |
| 30:9           | /          | /           | /                                                                                                                                              |
| 8              | R/W        | 0x0         | VA_CONFIG<br>Virtual Address Configuration<br>0: Read operation<br>1: Write operation                                                          |
| 7:1            | /          | /           | /                                                                                                                                              |
| 0              | R/WAC      | 0x0         | VA_CONFIG_START<br>0: No operation or operation is completed<br>1: Start<br>After the operation is completed, the bit can clear automatically. |

**Read operation process:**

- Write IOMMU\_VA\_REG [31:0];
- Write IOMMU\_VA\_CONFIG\_REG [8] to 0;
- Write IOMMU\_VA\_CONFIG\_REG [0] to 1 to start read-process;
- Query IOMMU\_VA\_CONFIG\_REG [0] until it is 0;
- Read IOMMU\_VA\_DATA\_REG [31:0].

**Write operation process:**

- Write IOMMU\_VA\_REG [31:0];
- Write IOMMU\_VA\_DATA\_REG [31:0];
- Write IOMMU\_VA\_CONFIG\_REG [8] to 1;
- Write IOMMU\_VA\_CONFIG\_REG [0] to 1 to start write-process;
- Query IOMMU\_VA\_CONFIG\_REG [0] until it is 0.

**2.9.6.49 0x0200 IOMMU PMU Enable Register (Default Value: 0x0000\_0000)**

| Offset: 0x0200 |            |             | Register Name: IOMMU_PMU_ENABLE_REG                                             |
|----------------|------------|-------------|---------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                     |
| 31:1           | /          | /           | /                                                                               |
| 0              | R/W        | 0x0         | PMU_ENABLE<br>0: Disable statistical function<br>1: Enable statistical function |

**2.9.6.50 0x0210 IOMMU PMU Clear Register (Default Value: 0x0000\_0000)**

| Offset: 0x0210 |            |             | Register Name: IOMMU_PMU_CLR_REG                                                                                                                                |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                     |
| 31:1           | /          | /           | /                                                                                                                                                               |
| 0              | R/WAC      | 0x0         | PMU_CLR<br>0: No clear operation or clear operation is completed<br>1: Clear counter data<br>After the operation is completed, the bit can clear automatically. |

**2.9.6.51 0x0230 IOMMU PMU Access Low 0 Register (Default Value: 0x0000\_0000)**

| Offset: 0x0230 |            |             | Register Name: IOMMU_PMU_ACCESS_LOW0_REG |
|----------------|------------|-------------|------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                              |

| Offset: 0x0230 |            |             | Register Name: IOMMU_PMU_ACCESS_LOW0_REG                                            |
|----------------|------------|-------------|-------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                         |
| 31:0           | R          | 0x0         | PMU_ACCESS_LOW0<br>Record total number of Micro TLB0 access, lower 32-bit register. |

#### 2.9.6.52 0x0234 IOMMU PMU Access High 0 Register (Default Value: 0x0000\_0000)

| Offset: 0x0234 |            |             | Register Name: IOMMU_PMU_ACCESS_HIGH0_REG                                            |
|----------------|------------|-------------|--------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                          |
| 31:11          | /          | /           | /                                                                                    |
| 10:0           | R          | 0x0         | PMU_ACCESS_HIGH0<br>Record total number of Micro TLB0 access, higher 32-bit register |

#### 2.9.6.53 0x0238 IOMMU PMU Hit Low 0 Register (Default Value: 0x0000\_0000)

| Offset: 0x0238 |            |             | Register Name: IOMMU_PMU_HIT_LOW0_REG                                         |
|----------------|------------|-------------|-------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                   |
| 31:0           | R          | 0x0         | PMU_HIT_LOW0<br>Record total number of Micro TLB0 hit, lower 32-bit register. |

#### 2.9.6.54 0x023C IOMMU PMU Hit High 0 Register (Default Value: 0x0000\_0000)

| Offset: 0x023C |            |             | Register Name: IOMMU_PMU_HIT_HIGH0_REG                                          |
|----------------|------------|-------------|---------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                     |
| 31:11          | /          | /           | /                                                                               |
| 10:0           | R          | 0x0         | PMU_HIT_HIGH0<br>Record total number of Micro TLB0 hit, higher 32-bit register. |

#### 2.9.6.55 0x0240 IOMMU PMU Access Low 1 Register (Default Value: 0x0000\_0000)

| Offset: 0x0240 |            |             | Register Name: IOMMU_PMU_ACCESS_LOW1_REG                                            |
|----------------|------------|-------------|-------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                         |
| 31:0           | R          | 0x0         | PMU_ACCESS_LOW1<br>Record total number of Micro TLB1 access, lower 32-bit register. |

**2.9.6.56 0x0244 IOMMU PMU Access High 1 Register (Default Value: 0x0000\_0000)**

| Offset: 0x0244 |            |             | Register Name: IOMMU_PMU_ACCESS_HIGH1_REG                                             |
|----------------|------------|-------------|---------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                           |
| 31:11          | /          | /           | /                                                                                     |
| 10:0           | R          | 0x0         | PMU_ACCESS_HIGH1<br>Record total number of Micro TLB1 access, higher 32-bit register. |

**2.9.6.57 0x0248 IOMMU PMU Hit Low 1 Register (Default Value: 0x0000\_0000)**

| Offset: 0x0248 |            |             | Register Name: IOMMU_PMU_HIT_LOW1_REG                                         |
|----------------|------------|-------------|-------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                   |
| 31:0           | R          | 0x0         | PMU_HIT_LOW1<br>Record total number of Micro TLB1 hit, lower 32-bit register. |

**2.9.6.58 0x024C IOMMU PMU Hit High 1 Register (Default Value: 0x0000\_0000)**

| Offset: 0x024C |            |             | Register Name: IOMMU_PMU_HIT_HIGH1_REG                                          |
|----------------|------------|-------------|---------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                     |
| 31:11          | /          | /           | /                                                                               |
| 10:0           | R          | 0x0         | PMU_HIT_HIGH1<br>Record total number of Micro TLB1 hit, higher 11-bit register. |

**2.9.6.59 0x0250 IOMMU PMU Access Low 2 Register (Default Value: 0x0000\_0000)**

| Offset: 0x0250 |            |             | Register Name: IOMMU_PMU_ACCESS_LOW2_REG                                            |
|----------------|------------|-------------|-------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                         |
| 31:0           | R          | 0x0         | PMU_ACCESS_LOW2<br>Record total number of Micro TLB2 access, lower 32-bit register. |

**2.9.6.60 0x0254 IOMMU PMU Access High 2 Register (Default Value: 0x0000\_0000)**

| Offset: 0x0254 |            |             | Register Name: IOMMU_PMU_ACCESS_HIGH2_REG                                             |
|----------------|------------|-------------|---------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                           |
| 31:11          | /          | /           | /                                                                                     |
| 10:0           | R          | 0x0         | PMU_ACCESS_HIGH2<br>Record total number of Micro TLB2 access, higher 11-bit register. |

## 2.9.6.61 0x0258 IOMMU PMU Hit Low 2 Register (Default Value: 0x0000\_0000)

| Offset: 0x0258 |            |             | Register Name: IOMMU_PMU_HIT_LOW2_REG                                         |
|----------------|------------|-------------|-------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                   |
| 31:0           | R          | 0x0         | PMU_HIT_LOW2<br>Record total number of Micro TLB2 hit, lower 32-bit register. |

## 2.9.6.62 0x025C IOMMU PMU Hit High 2 Register (Default Value: 0x0000\_0000)

| Offset: 0x025C |            |             | Register Name: IOMMU_PMU_HIT_HIGH2_REG                                          |
|----------------|------------|-------------|---------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                     |
| 31:11          | /          | /           | /                                                                               |
| 10:0           | R          | 0x0         | PMU_HIT_HIGH2<br>Record total number of Micro TLB2 hit, higher 11-bit register. |

## 2.9.6.63 0x0260 IOMMU PMU Access Low 3 Register (Default Value: 0x0000\_0000)

| Offset: 0x0260 |            |             | Register Name: IOMMU_PMU_ACCESS_LOW3_REG                                            |
|----------------|------------|-------------|-------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                         |
| 31:0           | R          | 0x0         | PMU_ACCESS_LOW3<br>Record total number of Micro TLB3 access, lower 32-bit register. |

## 2.9.6.64 0x0264 IOMMU PMU Access High 3 Register (Default Value: 0x0000\_0000)

| Offset: 0x0264 |            |             | Register Name: IOMMU_PMU_ACCESS_HIGH3_REG                                             |
|----------------|------------|-------------|---------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                           |
| 31:11          | /          | /           | /                                                                                     |
| 10:0           | R          | 0x0         | PMU_ACCESS_HIGH3<br>Record total number of Micro TLB3 access, higher 11-bit register. |

## 2.9.6.65 0x0268 IOMMU PMU Hit Low 3 Register (Default Value: 0x0000\_0000)

| Offset: 0x0268 |            |             | Register Name: IOMMU_PMU_HIT_LOW3_REG                                         |
|----------------|------------|-------------|-------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                   |
| 31:0           | R          | 0x0         | PMU_HIT_LOW3<br>Record total number of Micro TLB3 hit, lower 32-bit register. |

#### 2.9.6.66 0x026C IOMMU PMU Hit High 3 Register (Default Value: 0x0000\_0000)

| Offset: 0x026C |            |             | Register Name: IOMMU_PMU_HIT_HIGH3_REG                                          |
|----------------|------------|-------------|---------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                     |
| 31:11          | /          | /           | /                                                                               |
| 10:0           | R          | 0x0         | PMU_HIT_HIGH3<br>Record total number of Micro TLB3 hit, higher 11-bit register. |

#### 2.9.6.67 0x0270 IOMMU PMU Access Low 4 Register (Default Value: 0x0000\_0000)

| Offset: 0x0270 |            |             | Register Name: IOMMU_PMU_ACCESS_LOW4_REG                                            |
|----------------|------------|-------------|-------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                         |
| 31:0           | R          | 0x0         | PMU_ACCESS_LOW4<br>Record total number of Micro TLB4 access, lower 32-bit register. |

#### 2.9.6.68 0x0274 IOMMU PMU Access High 4 Register (Default Value: 0x0000\_0000)

| Offset: 0x0274 |            |             | Register Name: IOMMU_PMU_ACCESS_HIGH4_REG                                             |
|----------------|------------|-------------|---------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                           |
| 31:11          | /          | /           | /                                                                                     |
| 10:0           | R          | 0x0         | PMU_ACCESS_HIGH4<br>Record total number of Micro TLB4 access, higher 11-bit register. |

#### 2.9.6.69 0x0278 IOMMU PMU Hit Low 4 Register (Default Value: 0x0000\_0000)

| Offset: 0x0278 |            |             | Register Name: IOMMU_PMU_HIT_LOW4_REG                                         |
|----------------|------------|-------------|-------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                   |
| 31:0           | R          | 0x0         | PMU_HIT_LOW4<br>Record total number of Micro TLB4 hit, lower 32-bit register. |

#### 2.9.6.70 0x027C IOMMU PMU Hit High 4 Register (Default Value: 0x0000\_0000)

| Offset: 0x027C |            |             | Register Name: IOMMU_PMU_HIT_HIGH4_REG                                          |
|----------------|------------|-------------|---------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                     |
| 31:11          | /          | /           | /                                                                               |
| 10:0           | R          | 0x0         | PMU_HIT_HIGH4<br>Record total number of Micro TLB4 hit, higher 11-bit register. |

## 2.9.6.71 0x0280 IOMMU PMU Access Low 5 Register (Default Value: 0x0000\_0000)

| Offset: 0x0280 |            |             | Register Name: IOMMU_PMU_ACCESS_LOW5_REG                                            |
|----------------|------------|-------------|-------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                         |
| 31:0           | R          | 0x0         | PMU_ACCESS_LOW5<br>Record total number of Micro TLB5 access, lower 32-bit register. |

## 2.9.6.72 0x0284 IOMMU PMU Access High 5 Register (Default Value: 0x0000\_0000)

| Offset: 0x0284 |            |             | Register Name: IOMMU_PMU_ACCESS_HIGH5_REG                                             |
|----------------|------------|-------------|---------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                           |
| 31:11          | /          | /           | /                                                                                     |
| 10:0           | R          | 0x0         | PMU_ACCESS_HIGH5<br>Record total number of Micro TLB5 access, higher 11-bit register. |

## 2.9.6.73 0x0288 IOMMU PMU Hit Low 5 Register (Default Value: 0x0000\_0000)

| Offset: 0x0288 |            |             | Register Name: IOMMU_PMU_HIT_LOW5_REG                                         |
|----------------|------------|-------------|-------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                   |
| 31:0           | R          | 0x0         | PMU_HIT_LOW5<br>Record total number of Micro TLB5 hit, lower 32-bit register. |

## 2.9.6.74 0x028C IOMMU PMU Hit High 5 Register (Default Value: 0x0000\_0000)

| Offset: 0x028C |            |             | Register Name: IOMMU_PMU_HIT_HIGH5_REG                                          |
|----------------|------------|-------------|---------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                     |
| 31:11          | /          | /           | /                                                                               |
| 10:0           | R          | 0x0         | PMU_HIT_HIGH5<br>Record total number of Micro TLB5 hit, higher 11-bit register. |

## 2.9.6.75 0x0290 IOMMU PMU Access Low 6 Register (Default Value: 0x0000\_0000)

| Offset: 0x0290 |            |             | Register Name: IOMMU_PMU_ACCESS_LOW6_REG                                            |
|----------------|------------|-------------|-------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                         |
| 31:0           | R          | 0x0         | PMU_ACCESS_LOW6<br>Record total number of Micro TLB6 access, lower 32-bit register. |

**2.9.6.76 0x0294 IOMMU PMU Access High 6 Register (Default Value: 0x0000\_0000)**

| Offset: 0x0294 |            |             | Register Name: IOMMU_PMU_ACCESS_HIGH6_REG                                             |
|----------------|------------|-------------|---------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                           |
| 31:11          | /          | /           | /                                                                                     |
| 10:0           | R          | 0x0         | PMU_ACCESS_HIGH6<br>Record total number of Micro TLB6 access, higher 11-bit register. |

**2.9.6.77 0x0298 IOMMU PMU Hit Low 6 Register (Default Value: 0x0000\_0000)**

| Offset: 0x0298 |            |             | Register Name: IOMMU_PMU_HIT_LOW6_REG                                         |
|----------------|------------|-------------|-------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                   |
| 31:0           | R          | 0x0         | PMU_HIT_LOW6<br>Record total number of Micro TLB6 hit, lower 32-bit register. |

**2.9.6.78 0x029C IOMMU PMU Hit High 6 Register (Default Value: 0x0000\_0000)**

| Offset: 0x029C |            |             | Register Name: IOMMU_PMU_HIT_HIGH6_REG                                          |
|----------------|------------|-------------|---------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                     |
| 31:11          | /          | /           | /                                                                               |
| 10:0           | R          | 0x0         | PMU_HIT_HIGH6<br>Record total number of Micro TLB6 hit, higher 11-bit register. |

**2.9.6.79 0x02D0 IOMMU PMU Access Low 7 Register (Default Value: 0x0000\_0000)**

| Offset: 0x02D0 |            |             | Register Name: IOMMU_PMU_ACCESS_LOW7_REG                                           |
|----------------|------------|-------------|------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                        |
| 31:0           | R          | 0x0         | PMU_ACCESS_LOW7<br>Record total number of Macro TLB access, lower 32-bit register. |

**2.9.6.80 0x02D4 IOMMU PMU Access High 7 Register (Default Value: 0x0000\_0000)**

| Offset: 0x02D4 |            |             | Register Name: IOMMU_PMU_ACCESS_HIGH7_REG                                            |
|----------------|------------|-------------|--------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                          |
| 31:11          | /          | /           | /                                                                                    |
| 10:0           | R          | 0x0         | PMU_ACCESS_HIGH7<br>Record total number of Macro TLB access, higher 11-bit register. |

#### 2.9.6.81 0x02D8 IOMMU PMU Hit Low 7 Register (Default Value: 0x0000\_0000)

| Offset: 0x02D8 |            |             | Register Name: IOMMU_PMU_HIT_LOW7_REG                                        |
|----------------|------------|-------------|------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                  |
| 31:0           | R          | 0x0         | PMU_HIT_LOW7<br>Record total number of Macro TLB hit, lower 32-bit register. |

#### 2.9.6.82 0x02DC IOMMU PMU Hit High 7 Register (Default Value: 0x0000\_0000)

| Offset: 0x02DC |            |             | Register Name: IOMMU_PMU_HIT_HIGH7_REG                                         |
|----------------|------------|-------------|--------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                    |
| 31:11          | /          | /           | /                                                                              |
| 10:0           | R          | 0x0         | PMU_HIT_HIGH7<br>Record total number of Macro TLB hit, higher 11-bit register. |

#### 2.9.6.83 0x02E0 IOMMU PMU Access Low 8 Register (Default Value: 0x0000\_0000)

| Offset: 0x02E0 |            |             | Register Name: IOMMU_PMU_ACCESS_LOW8_REG                                           |
|----------------|------------|-------------|------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                        |
| 31:0           | R          | 0x0         | PMU_ACCESS_LOW8<br>Record total number of PTW Cache access, lower 32-bit register. |

#### 2.9.6.84 0x02E4 IOMMU PMU Access High 8 Register (Default Value: 0x0000\_0000)

| Offset: 0x02E4 |            |             | Register Name: IOMMU_PMU_ACCESS_HIGH8_REG                                            |
|----------------|------------|-------------|--------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                          |
| 31:11          | /          | /           | /                                                                                    |
| 10:0           | R          | 0x0         | PMU_ACCESS_HIGH8<br>Record total number of PTW Cache access, higher 11-bit register. |

#### 2.9.6.85 0x02E8 IOMMU PMU Hit Low 8 Register (Default Value: 0x0000\_0000)

| Offset: 0x02E8 |            |             | Register Name: IOMMU_PMU_HIT_LOW8_REG                                        |
|----------------|------------|-------------|------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                  |
| 31:0           | R          | 0x0         | PMU_HIT_LOW8<br>Record total number of PTW Cache hit, lower 32-bit register. |

**2.9.6.86 0x02EC IOMMU PMU Hit High 8 Register (Default Value: 0x0000\_0000)**

| Offset: 0x02EC |            |             | Register Name: IOMMU_PMU_HIT_HIGH8_REG                                         |
|----------------|------------|-------------|--------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                    |
| 31:11          | /          | /           | /                                                                              |
| 10:0           | R          | 0x0         | PMU_HIT_HIGH8<br>Record total number of PTW Cache hit, higher 11-bit register. |

**2.9.6.87 0x0300 IOMMU Total Latency Low 0 Register (Default Value: 0x0000\_0000)**

| Offset: 0x0300 |            |             | Register Name: IOMMU_PMU_TL_LOW0_REG                                   |
|----------------|------------|-------------|------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                            |
| 31:0           | R          | 0x0         | PMU_TL_LOW0<br>Record total latency of Master0, lower 32-bit register. |

**2.9.6.88 0x0304 IOMMU Total Latency High 0 Register (Default Value: 0x0000\_0000)**

| Offset: 0x0304 |            |             | Register Name: IOMMU_PMU_TL_HIGH0_REG                                    |
|----------------|------------|-------------|--------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                              |
| 31:18          | /          | /           | /                                                                        |
| 17:0           | R          | 0x0         | PMU_TL_HIGH0<br>Record total latency of Master0, higher 18-bit register. |

**2.9.6.89 0x0308 IOMMU Max Latency 0 Register (Default Value: 0x0000\_0000)**

| Offset: 0x0308 |            |             | Register Name: IOMMU_PMU_ML0_REG              |
|----------------|------------|-------------|-----------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                   |
| 31:0           | R          | 0x0         | PMU_ML0<br>Record the max latency of Master0. |

**2.9.6.90 0x0310 IOMMU Total Latency Low 1 Register (Default Value: 0x0000\_0000)**

| Offset: 0x0310 |            |             | Register Name: IOMMU_PMU_TL_LOW1_REG                                   |
|----------------|------------|-------------|------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                            |
| 31:0           | R          | 0x0         | PMU_TL_LOW1<br>Record total latency of Master1, lower 32-bit register. |

## 2.9.6.91 0x0314 IOMMU Total Latency High 1 Register (Default Value: 0x0000\_0000)

| Offset: 0x0314 |            |             | Register Name: IOMMU_PMU_TL_HIGH1_REG                                    |
|----------------|------------|-------------|--------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                              |
| 31:18          | /          | /           | /                                                                        |
| 17:0           | R          | 0x0         | PMU_TL_HIGH1<br>Record total latency of Master1, higher 18-bit register. |

## 2.9.6.92 0x0318 IOMMU Max Latency 1 Register (Default Value: 0x0000\_0000)

| Offset: 0x0318 |            |             | Register Name: IOMMU_PMU_ML1_REG              |
|----------------|------------|-------------|-----------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                   |
| 31:0           | R          | 0x0         | PMU_ML1<br>Record the max latency of Master1. |

## 2.9.6.93 0x0320 IOMMU Total Latency Low 2 Register (Default Value: 0x0000\_0000)

| Offset: 0x0320 |            |             | Register Name: IOMMU_PMU_TL_LOW2_REG                                   |
|----------------|------------|-------------|------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                            |
| 31:0           | R          | 0x0         | PMU_TL_LOW2<br>Record total latency of Master2, lower 32-bit register. |

## 2.9.6.94 0x0324 IOMMU Total Latency High 2 Register (Default Value: 0x0000\_0000)

| Offset: 0x0324 |            |             | Register Name: IOMMU_PMU_TL_HIGH2_REG                                    |
|----------------|------------|-------------|--------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                              |
| 31:18          | /          | /           | /                                                                        |
| 17:0           | R          | 0x0         | PMU_TL_HIGH2<br>Record total latency of Master2, higher 18-bit register. |

## 2.9.6.95 0x0328 IOMMU Max Latency 2 Register (Default Value: 0x0000\_0000)

| Offset: 0x0328 |            |             | Register Name: IOMMU_PMU_ML2_REG              |
|----------------|------------|-------------|-----------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                   |
| 31:0           | R          | 0x0         | PMU_ML2<br>Record the max latency of Master2. |

## 2.9.6.96 0x0330 IOMMU Total Latency Low 3 Register (Default Value: 0x0000\_0000)

| Offset: 0x0330 | Register Name: IOMMU_PMU_TL_LOW3_REG |
|----------------|--------------------------------------|
|----------------|--------------------------------------|

| Bit  | Read/Write | Default/Hex | Description                                                            |
|------|------------|-------------|------------------------------------------------------------------------|
| 31:0 | R          | 0x0         | PMU_TL_LOW3<br>Record total latency of Master3, lower 32-bit register. |

#### 2.9.6.97 0x0334 IOMMU Total Latency High 3 Register (Default Value: 0x0000\_0000)

| Offset: 0x0334 |            |             | Register Name: IOMMU_PMU_TL_HIGH3_REG                                    |
|----------------|------------|-------------|--------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                              |
| 31:18          | /          | /           | /                                                                        |
| 17:0           | R          | 0x0         | PMU_TL_HIGH3<br>Record total latency of Master3, higher 18-bit register. |

#### 2.9.6.98 0x0338 IOMMU Max Latency 3 Register (Default Value: 0x0000\_0000)

| Offset: 0x0338 |            |             | Register Name: IOMMU_PMU_ML3_REG              |
|----------------|------------|-------------|-----------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                   |
| 31:0           | R          | 0x0         | PMU_ML3<br>Record the max latency of Master3. |

#### 2.9.6.99 0x0340 IOMMU Total Latency Low 4 Register (Default Value: 0x0000\_0000)

| Offset: 0x0340 |            |             | Register Name: IOMMU_PMU_TL_LOW4_REG                                   |
|----------------|------------|-------------|------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                            |
| 31:0           | R          | 0x0         | PMU_TL_LOW4<br>Record total latency of Master4, lower 32-bit register. |

#### 2.9.6.100 0x0344 IOMMU Total Latency High 4 Register (Default Value: 0x0000\_0000)

| Offset: 0x0344 |            |             | Register Name: IOMMU_PMU_TL_HIGH4_REG                                    |
|----------------|------------|-------------|--------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                              |
| 31:18          | /          | /           | /                                                                        |
| 17:0           | R          | 0x0         | PMU_TL_HIGH4<br>Record total latency of Master4, higher 18-bit register. |

#### 2.9.6.101 0x0348 IOMMU Max Latency 4 Register (Default Value: 0x0000\_0000)

| Offset: 0x0348 |            |             | Register Name: IOMMU_PMU_ML4_REG              |
|----------------|------------|-------------|-----------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                   |
| 31:0           | R          | 0x0         | PMU_ML4<br>Record the max latency of Master4. |

**2.9.6.102 0x0350 IOMMU Total Latency Low 5 Register (Default Value: 0x0000\_0000)**

| Offset: 0x0350 |            |             | Register Name: IOMMU_PMU_TL_LOW5_REG                                   |
|----------------|------------|-------------|------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                            |
| 31:0           | R          | 0x0         | PMU_TL_LOW5<br>Record total latency of Master5, lower 32-bit register. |

**2.9.6.103 0x0354 IOMMU Total Latency High 5 Register (Default Value: 0x0000\_0000)**

| Offset: 0x0354 |            |             | Register Name: IOMMU_PMU_TL_HIGH5_REG                                    |
|----------------|------------|-------------|--------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                              |
| 31:18          | /          | /           | /                                                                        |
| 17:0           | R          | 0x0         | PMU_TL_HIGH5<br>Record total latency of Master5, higher 18-bit register. |

**2.9.6.104 0x0358 IOMMU Max Latency 5 Register (Default Value: 0x0000\_0000)**

| Offset: 0x0358 |            |             | Register Name: IOMMU_PMU_ML5_REG              |
|----------------|------------|-------------|-----------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                   |
| 31:0           | R          | 0x0         | PMU_ML5<br>Record the max latency of Master5. |

**2.9.6.105 0x0360 IOMMU Total Latency Low 6 Register (Default Value: 0x0000\_0000)**

| Offset: 0x0360 |            |             | Register Name: IOMMU_PMU_TL_LOW6_REG                                   |
|----------------|------------|-------------|------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                            |
| 31:0           | R          | 0x0         | PMU_TL_LOW6<br>Record total latency of Master6, lower 32-bit register. |

**2.9.6.106 0x0364 IOMMU Total Latency High 6 Register (Default Value: 0x0000\_0000)**

| Offset: 0x0364 |            |             | Register Name: IOMMU_PMU_TL_HIGH6_REG                                    |
|----------------|------------|-------------|--------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                              |
| 31:18          | /          | /           | /                                                                        |
| 17:0           | R          | 0x0         | PMU_TL_HIGH6<br>Record total latency of Master6, higher 18-bit register. |

**2.9.6.107 0x0368 IOMMU Max Latency 6 Register (Default Value: 0x0000\_0000)**

| Offset: 0x0368 | Register Name: IOMMU_PMU_ML6_REG |
|----------------|----------------------------------|
|----------------|----------------------------------|

| Bit  | Read/Write | Default/Hex | Description                                   |
|------|------------|-------------|-----------------------------------------------|
| 31:0 | R          | 0x0         | PMU_ML6<br>Record the max latency of Master6. |



## 2.10 Message Box (MSGBOX)

### 2.10.1 Overview

The Message Box (MSGBOX) provides interrupt communication mechanism for on-chip processor.

The MSGBOX has the following features:

- Supports communication between two CPUs through one way channels. Each CPU has one MSGBOX and can only read or write in one communication
  - CPUX\_MSGBOX: CPUS/RISC-V write; ARM CPU read
  - CPUS\_MSGBOX: ARM CPU/RISC-V write; CPUS read
  - RISCV\_MSGBOX: ARM CPU/CPUS write; RISC-V read
- The channel between two CPU has 4 channels, and the FIFO depth of a channel is 8 x 32 bits
- Supports interrupts

### 2.10.2 Block Diagram

The following figure shows the block diagram of the message box.

Figure 2-22 Message Box Block Diagram



Each CPU has 4 channels. The two channels can be configured to be secure by software, the other two channels can be configured to be non-secure by software. The two secure channels or two non-secure channels can be configured as one synchronous box (Sending a message requires a response) or one asynchronous box (Sending a message does not require a response).

### 2.10.3 Functional Description

#### 2.10.3.1 Clock and Reset

The MSGBOX is mounted on AHB. Before accessing the MSGBOX registers, you need to de-assert the MSGBOX reset signal on AHB bus and then open the MSGBOX gating signal on AHB bus.

#### 2.10.3.2 Transmitter/Receiver Mode

At the same channel, user1 is fixed as transmitter, user0 is fixed as receiver.

#### 2.10.3.3 Typical Application

Several masters can build communication by configuring the MSGBOX. The communication parties have 4 channels. In a channel, the user1 is fixed as the transmitter and the user0 is fixed as the receiver. During the communication process, the current status can be judged through the interrupt or FIFO status.

#### 2.10.3.4 Interrupt

Each channel can configure independently the interrupt enable bit, a read interrupt will be generated when the channel is empty, a write interrupt will be generated when the channel is non-full. For each CPU, all channels generate a read interrupt together, that is, if only a channel is non-full, the read interrupt will be generated, this channel can be obtained by querying the interrupt status register.

#### 2.10.3.5 FIFO Status

When channel FIFO is non-full, the FIFO\_NOT\_AVA\_FLAG is 0, at the moment the FIFO can be written.

When channel FIFO is full, the FIFO\_NOT\_AVA\_FLAG is 1, at the moment if FIFO is written again, the first data of FIFO can be covered.

See [MSGBOX\\_FIFO\\_STATUS\\_REG](#) for FIFO status.

## 2.10.4 Programming Guidelines

### 2.10.4.1 Checking the Transfer Status via the Interrupt

Follow the steps below to check the transfer status:

**Step 1** Enable the interrupt for the channel: Configure the interrupt enable bits of transmitter/receiver through [MSGBOX\\_WR\\_IRQ\\_EN\\_REG/MSGBOX\\_RD\\_IRQ\\_EN\\_REG](#). (user0: RX interrupt enable; user1: TX interrupt enable)

**Step 2** Check the IRQ status of the corresponding queue through [MSGBOX\\_WR\\_IRQ\\_STATUS\\_REG/MSGBOX\\_RD\\_IRQ\\_STATUS\\_REG](#).

- If the FIFO is not full, the channel generates a transmission interrupt to remind the transmitter to transmit data. Write data to the FIFO in the interrupt handler, then clear the pending bit of the transmitter in [MSGBOX\\_WR\\_IRQ\\_STATUS\\_REG](#) and the enable bit of the transmitter in [MSGBOX\\_WR\\_IRQ\\_EN\\_REG](#).
- If the FIFO has new data, the channel generates a reception interrupt to remind the receiver to receive data. Read data from the FIFO in interrupt handler, then clear the pending bit of the receiver in [MSGBOX\\_RD\\_IRQ\\_STATUS\\_REG](#) and the enable bit of the receiver in [MSGBOX\\_RD\\_IRQ\\_EN\\_REG](#).

### 2.10.4.2 Checking the Transfer Status via the FIFO

Follow the steps below to check the FIFO status of the corresponding queue:

- If the FIFO is not full, the transmitter fills the FIFO to 8\*32 bits.
- If the FIFO is full, the receiver reads the FIFO data, and reads [MSGBOX\\_FIFO\\_STATUS\\_REG](#) to acquire the current FIFO data amount and the FIFO data amount before reading, which means no data is dropped.

### 2.10.4.3 Transmitting/Receiving Message

The following figure shows the communication process between CPUX\_MSGBOX and CPUS\_MSGBOX.

CPUX\_MSGBOX: Receiving message

CPUS\_MSGBOX: Transmitting message

Figure 2-23 The Communication Process between CPUX\_MSGBOX and CPUS\_MSGBOX



## 2.10.5 Register List

| Module Name  | Base Address |
|--------------|--------------|
| CPUX_MSGBOX  | 0x0300 3000  |
| CPUS_MSGBOX  | 0x0709 4000  |
| RISCV_MSGBOX | 0x0713 6000  |

| Parameter | Description                                            | Value  |
|-----------|--------------------------------------------------------|--------|
| N         | The CPU numbers that communicates with the current CPU | 0 or 2 |
| P         | The channel numbers between two communication CPU      | 0-3    |

| MSGBOX       | CPU         | The Value of N |
|--------------|-------------|----------------|
| CPUX_MSGBOX  | CPUS->CPUX  | N=0            |
| CPUX_MSGBOX  | RISCV->CPUX | N=2            |
| CPUS_MSGBOX  | CPUX->CPUS  | N=0            |
| CPUS_MSGBOX  | RISCV->CPUS | N=2            |
| RISCV_MSGBOX | CPUS->RISCV | N=0            |
| RISCV_MSGBOX | CPUX->RISCV | N=2            |

| Register Name               | Offset                                  | Description                         |
|-----------------------------|-----------------------------------------|-------------------------------------|
| MSGBOX_RD_IRQ_EN_REG        | 0x0020+N*0x0100(N=0, 2)                 | MSGBOX Read IRQ Enable Register     |
| MSGBOX_RD_IRQ_STATUS_REG    | 0x0024+N*0x0100(N=0, 2)                 | MSGBOX Read IRQ Status Register     |
| MSGBOX_WR_IRQ_EN_REG        | 0x0030+N*0x0100(N=0, 2)                 | MSGBOX Write IRQ Enable Register    |
| MSGBOX_WR_IRQ_STATUS_REG    | 0x0034+N*0x0100(N=0, 2)                 | MSGBOX Write IRQ Status Register    |
| MSGBOX_DEBUG_REG            | 0x0040+N*0x0100(N=0, 2)                 | MSGBOX Debug Register               |
| MSGBOX_FIFO_STATUS_REG      | 0x0050+N*0x0100+P*0x0004(N=0, 2)(P=0-3) | MSGBOX FIFO Status Register         |
| MSGBOX_MSG_STATUS_REG       | 0x0060+N*0x0100+P*0x0004(N=0, 2)(P=0-3) | MSGBOX Message Status Register      |
| MSGBOX_MSG_REG              | 0x0070+N*0x0100+P*0x0004(N=0, 2)(P=0-3) | MSGBOX Message Queue Register       |
| MSGBOX_WR_INT_THRESHOLD_REG | 0x0080+N*0x0100+P*0x0004(N=0, 2)(P=0-3) | MSGBOX Write IRQ Threshold Register |

## 2.10.6 Register Description

### 2.10.6.1 0x0020+N\*0x0100(N=0, 2) MSGBOX Read IRQ Enable Register (Default Value: 0x0000\_0000)

| Offset:<br>0x0020+N*0x0100(N=0, 2) |     |             | Register Name: MSGBOX_RD_IRQ_EN_REG                                                                                                                                          |
|------------------------------------|-----|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                                | R/W | Default/Hex | Description                                                                                                                                                                  |
| 31:7                               | /   | /           | /                                                                                                                                                                            |
| 6                                  | R/W | 0x0         | RECEPTION_MQ3_IRQ_EN<br>Reception Channel3 Interrupt Enable<br>0: Disable<br>1: Enable (It will notify user 0 by interrupt when Message Queue 3 has received a new message.) |
| 5                                  | /   | /           | /                                                                                                                                                                            |

| Offset:<br>0x0020+N*0x0100(N=0, 2) |     |             | Register Name: MSGBOX_RD_IRQ_EN_REG                                                                                                                                          |
|------------------------------------|-----|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                                | R/W | Default/Hex | Description                                                                                                                                                                  |
| 4                                  | R/W | 0x0         | RECEPTION_MQ2_IRQ_EN<br>Reception Channel2 Interrupt Enable<br>0: Disable<br>1: Enable (It will notify user 0 by interrupt when Message Queue 2 has received a new message.) |
| 3                                  | /   | /           | /                                                                                                                                                                            |
| 2                                  | R/W | 0x0         | RECEPTION_MQ1_IRQ_EN<br>Reception Channel1 Interrupt Enable<br>0: Disable<br>1: Enable (It will notify user 0 by interrupt when Message Queue 1 has received a new message.) |
| 1                                  | /   | /           | /                                                                                                                                                                            |
| 0                                  | R/W | 0x0         | RECEPTION_MQ0_IRQ_EN<br>Reception Channel0 Interrupt Enable<br>0: Disable<br>1: Enable (It will notify user 0 by interrupt when Message Queue 0 has received a new message.) |

#### 2.10.6.2 0x0024+N\*0x0100(N=0, 2) MSGBOX Read IRQ Status Register (Default Value: 0x0000\_0000)

| Offset:<br>0x0024+N*0x0100(N=0, 2) |     |             | Register Name: MSGBOX_RD_IRQ_STATUS_REG                                                                                                                                                                                |
|------------------------------------|-----|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                                | R/W | Default/Hex | Description                                                                                                                                                                                                            |
| 31:3                               | /   | /           | /                                                                                                                                                                                                                      |
| 6                                  | R/W | 0x0         | RECEPTION_MQ3_IRQ_PEND<br>Reception Channel3 Interrupt Pending<br>0: No effect<br>1: Pending. This bit will be pending for user 0 when Message Queue 3 has received a new message. Set one to this bit will clear it.  |
| 5                                  | /   | /           | /                                                                                                                                                                                                                      |
| 4                                  | R/W | 0x0         | RECEPTION_MQ2_IRQ_PEND.<br>Reception Channel2 Interrupt Pending<br>0: No effect<br>1: Pending. This bit will be pending for user 0 when Message Queue 2 has received a new message. Set one to this bit will clear it. |
| 3                                  | /   | /           | /                                                                                                                                                                                                                      |
| 2                                  | R/W | 0x0         | RECEPTION_MQ1_IRQ_PEND<br>Reception Channel1 Interrupt Pending                                                                                                                                                         |

| Offset:<br>0x0024+N*0x0100(N=0, 2) |     |             | Register Name: MSGBOX_RD_IRQ_STATUS_REG                                                                                                                                                                               |
|------------------------------------|-----|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                                | R/W | Default/Hex | Description                                                                                                                                                                                                           |
|                                    |     |             | 0: No effect<br>1: Pending. This bit will be pending for user 0 when Message Queue 1 has received a new message. Set one to this bit will clear it.                                                                   |
| 1                                  | /   | /           | /                                                                                                                                                                                                                     |
| 0                                  | R/W | 0x0         | RECEPTION_MQ0_IRQ_PEND<br>Reception Channel0 Interrupt Pending<br>0: No effect<br>1: Pending. This bit will be pending for user 0 when Message Queue 0 has received a new message. Set one to this bit will clear it. |

#### 2.10.6.3 0x0030+N\*0x0100(N=0, 2) MSGBOX Write IRQ Enable Register (Default Value: 0x0000\_0000)

| Offset:<br>0x0030+N*0x0100(N=0, 2) |     |             | Register Name: MSGBOX_WR_IRQ_EN_REG                                                                                                                                                         |
|------------------------------------|-----|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                                | R/W | Default/Hex | Description                                                                                                                                                                                 |
| 31:8                               | /   | /           | /                                                                                                                                                                                           |
| 7                                  | R/W | 0x0         | TRANSMIT_MQ3_IRQ_EN<br>Transmit Channel3 Interrupt Enable.<br>0: Disable<br>1: Enable (It will notify user 1 by interrupt when Message Queue 3 empty level reach the configured threshold.) |
| 6                                  | /   | /           | /                                                                                                                                                                                           |
| 5                                  | R/W | 0x0         | TRANSMIT_MQ2_IRQ_EN<br>Transmit Channel2 Interrupt Enable.<br>0: Disable<br>1: Enable (It will Notify user 1 by interrupt when Message Queue 2 empty level reach the configured threshold.) |
| 4                                  | /   | /           | /                                                                                                                                                                                           |
| 3                                  | R/W | 0x0         | TRANSMIT_MQ1_IRQ_EN<br>Transmit Channel1 Interrupt Enable.<br>0: Disable<br>1: Enable (It will Notify user 1 by interrupt when Message Queue 1 empty level reach the configured threshold.) |
| 2                                  | /   | /           | /                                                                                                                                                                                           |
| 1                                  | R/W | 0x0         | TRANSMIT_MQ0_IRQ_EN<br>Transmit Channel0 Interrupt Enable<br>0: Disable<br>1: Enable (It will Notify user 1 by interrupt when Message Queue                                                 |

| Offset:<br>0x0030+N*0x0100(N=0, 2) |     |             | Register Name: MSGBOX_WR_IRQ_EN_REG            |
|------------------------------------|-----|-------------|------------------------------------------------|
| Bit                                | R/W | Default/Hex | Description                                    |
|                                    |     |             | 0 empty level reach the configured threshold.) |
| 0                                  | /   | /           | /                                              |

#### 2.10.6.4 0x0034+N\*0x0100(N=0, 2) MSGBOX Write IRQ Status Register (Default Value: 0x0000\_0000)

| Offset:<br>0x0034+N*0x0100(N=0, 2) |     |             | Register Name: MSGBOX_WR_IRQ_STATUS_REG                                                                                                                                                                                              |
|------------------------------------|-----|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                                | R/W | Default/Hex | Description                                                                                                                                                                                                                          |
| 31:8                               | /   | /           | /                                                                                                                                                                                                                                    |
| 7                                  | R/W | 0x0         | TRANSMIT_MQ3_IRQ_PEND<br>Transmit Channel3 Interrupt Pending<br>0: No effect<br>1: Pending. This bit will be pending for user 1 when Message Queue 3 empty level reach the configured threshold. Set one to this bit will clear it.  |
| 6                                  | /   | /           | /                                                                                                                                                                                                                                    |
| 5                                  | R/W | 0x0         | TRANSMIT_MQ2_IRQ_PEND<br>Transmit Channel2 Interrupt Pending<br>0: No effect<br>1: Pending. This bit will be pending for user 1 when Message Queue 2 empty level reach the configured threshold. Set one to this bit will clear it.  |
| 4                                  | /   | /           | /                                                                                                                                                                                                                                    |
| 3                                  | R/W | 0x0         | TRANSMIT_MQ1_IRQ_PEND<br>Transmit Channel1 Interrupt Pending<br>0: No effect<br>1: Pending. This bit will be pending for user 1 when Message Queue 1 empty level reach the configured threshold. Set one to this bit will clear it.  |
| 2                                  | /   | /           | /                                                                                                                                                                                                                                    |
| 1                                  | R/W | 0x0         | TRANSMIT_MQ0_IRQ_PEND<br>Transmit Channel0 Interrupt Pending<br>0: No effect,<br>1: Pending. This bit will be pending for user 1 when Message Queue 0 empty level reach the configured threshold. Set one to this bit will clear it. |
| 0                                  | /   | /           | /                                                                                                                                                                                                                                    |

## 2.10.6.5 0x0040+N\*0x0100(N=0, 2) MSGBOX Debug Register (Default Value: 0x0000\_0000)

| Offset:<br>0x0040+N*0x0100(N=0, 2) |     |             | Register Name: MSGBOX_DEBUG_REG                                                                                                                                                                                                               |
|------------------------------------|-----|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                                | R/W | Default/Hex | Description                                                                                                                                                                                                                                   |
| 31:12                              | /   | /           | /                                                                                                                                                                                                                                             |
| 11:8                               | R/W | 0x0         | FIFO_CTRL<br>FIFO Control<br>MQ [7:0] Control. In the debug mode, the corresponding FIFO channel will disable and only one register space valid for a message exchange.<br>0: Normal Mode.<br>1: Disable the corresponding FIFO (Clear FIFO). |
| 7:1                                | /   | /           | /                                                                                                                                                                                                                                             |
| 0                                  | R/W | 0x0         | DEBUG_MODE<br>Debug Mode<br>In the Debug Mode, each user can transmit messages to itself through each Message Queue.<br>0: Normal Mode<br>1: Debug Mode.                                                                                      |

## 2.10.6.6 0x0050+N\*0x0100+P\*0x0004(N=0, 2) (P=0-3) MSGBOX FIFO Status Register (Default Value: 0x0000\_0000)

| Offset:<br>0x0050+N*0x0100+P*0x0004(N=0, 2)(P=0-3) |     |             | Register Name: MSGBOX_FIFO_STATUS_REG                                                                                                                                                                                                                                                  |
|----------------------------------------------------|-----|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                                                | R/W | Default/Hex | Description                                                                                                                                                                                                                                                                            |
| 31: 1                                              | /   | /           | /                                                                                                                                                                                                                                                                                      |
| 0                                                  | R   | 0x0         | FIFO_NOT_AVA_FLAG<br>FIFO is not available flag<br>0: The Message FIFO queue empty level is not reached the configured threshold.<br>1: The Message FIFO queue empty level reached the configured threshold.<br>This FIFO status register has the status related to the message queue. |

**2.10.6.7 0x0060+N\*0x0100+P\*0x0004(N=0, 2) (P=0-3) MSGBOX Message Status Register (Default Value: 0x0000\_0000)**

| Offset: 0x0060+N*0x0100+P*0x0004(N=0, 2)(P=0-3) |     |             | Register Name: MSGBOX_MSG_STATUS_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------------------------------------------------|-----|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                                             | R/W | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 31:4                                            | /   | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 3:0                                             | R   | 0x0         | <p>MSG_NUM<br/>Message Number<br/>Number of unread messages in the message queue. Here, limited to eight messages per message queue.</p> <p>0000: There is no message in the message FIFO queue.</p> <p>0001: There is 1 message in the message FIFO queue.</p> <p>0010: There are 2 messages in the message FIFO queue.</p> <p>0011: There are 3 messages in the message FIFO queue.</p> <p>0100: There are 4 messages in the message FIFO queue.</p> <p>0101: There are 5 messages in the message FIFO queue.</p> <p>0110: There are 6 messages in the message FIFO queue.</p> <p>0111: There are 7 messages in the message FIFO queue.</p> <p>1000: There are 8 messages in the message FIFO queue.</p> <p>1001-1111:/</p> |

**2.10.6.8 0x0070+N\*0x0100+P\*0x0004(N=0, 2) (P=0-3) MSGBOX Message Queue Register (Default Value: 0x0000\_0000)**

| Offset:<br>0x0070+N*0x0100+P*0x0004(N=0, 2)(P=0-3) |     |             | Register Name: MSGBOX_MSG_REG                                                                                      |
|----------------------------------------------------|-----|-------------|--------------------------------------------------------------------------------------------------------------------|
| Bit                                                | R/W | Default/Hex | Description                                                                                                        |
| 31:0                                               | R/W | 0x0         | <p>MSG_QUE<br/>The message register stores the next to be read message of the message FIFO queue. Reads remove</p> |

| Offset:<br>0x0070+N*0x0100+P*0x0004(N=0, 2)(P=0-3) |     |             | Register Name: MSGBOX_MSG_REG    |
|----------------------------------------------------|-----|-------------|----------------------------------|
| Bit                                                | R/W | Default/Hex | Description                      |
|                                                    |     |             | the message from the FIFO queue. |

2.10.6.9 0x0080+N\*0x0100+P\*0x0004(N=0, 2) (P=0-3) MSGBOX Write IRQ Threshold Register (Default Value: 0x0000\_0000)

| Offset: 0x0080+N*0x0100+P*0x0004(N=0, 2)(P=0-3) |     |             | Register Name:<br>MSGBOX_WR_INT_THRESHOLD_REG                                                                                            |
|-------------------------------------------------|-----|-------------|------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                                             | R/W | Default/Hex | Description                                                                                                                              |
| 31:2                                            | /   | /           | /                                                                                                                                        |
| 1:0                                             | R/W | 0x0         | MSG_WR_INT_THRESHOLD_CFG<br>Configure the FIFO empty level to trigger the write interrupt for user1.<br>00: 1<br>01: 2<br>10: 4<br>11: 8 |

## 2.11 Power Reset Clock Management (PRCM)

### 2.11.1 Overview

The Power Reset Clock Management (PRCM) module is one of the most import design aspects in this system. It provides a versatile supporting multiple power-management techniques. And it also manages the gating and enabling of the clocks to the device modules.

The system-level reset management provides correct reset routing and sequencing when one or more devices are stacked together in the same package. The device-level reset management provides reset routing to relevant devices, such as CPUS\_TIMER, S\_UART and so on.

The PRCM has the following features:

- Two PRCMs in CPUS domain: PRCM and MCU\_PRCM
- 1 PLL
- CPUS Clock Configuration
- APBS Clock Configuration
- CPUS Module Clock Configuration
- CPUS Module BUS Gating and Reset
- RAM configure Control for PRCM



#### NOTE

- There are 15 PLLs in A523. 10 PLLs in CCU, 4 PLLs in CPUX system, and 1 PLL in MCU\_PRCM.
- PRCM describes module clocks in CPUS domain.
- For clock description of CPUX system, please refer to section 2.2.3.2 CPU PLL Distribution and Clock Sources.
- For module clocks in CPUX domain (excluding the clocks of CPUX system.), please refer to section 2.5 Clock Controller Unit (CCU).

## 2.11.2 Functional Description

### 2.11.2.1 System Bus Tree

The following figures show the diagram of the System Bus Tree.

Figure 2-24 System Bus Tree of PRCM



Figure 2-25 System Bus Tree of MCU\_PRCM



### 2.11.2.2 Bus Clock Tree

The following figures show a block diagram of the clock tree Diagram in CPUS domain.

Figure 2-26 Bus Clock Tree



### 2.11.2.3 PLL Distribution

The following figures show the block diagram of the PLL distribution.

**Figure 2-27 PLL Distribution of PRCM**



PERIOPLL(1X) is PERI0\_600M = PERIOPLL2X/2. For detailed information of PLL\_PERI0, see section 2.5.3.3 PLL Features.

**Figure 2-28 PLL Distribution of MCU\_PRCM**



### 2.11.2.4 PLL Features

The following table shows the PLL features.

**Table 2-18 PLL Features**

| PLL        | Stable Operating Frequency | Actual Operating Frequency                                                                                        | Spread Spectrum | Linear FM | Pk-Pk   | Lock Time |
|------------|----------------------------|-------------------------------------------------------------------------------------------------------------------|-----------------|-----------|---------|-----------|
| PLL_AUDIO1 | 1.52 GHz-3.1GHz            | Integer mode:<br>1/2x: 1.536 GHz<br>1/5x: 614.4 MHz<br>Decimal mode:<br>1/2x: 1.1179648 GHz<br>1/5x: 471.8592 MHz | Yes             | No        | < 200ps | 500us     |

## 2.11.3 Programming Guidelines

### 2.11.3.1 Enabling the PLL

Follow the steps below to enable the PLL:

**Step 1** Configure the N, M, and P factors of the PLL control register.

**Step 2** Write 1 to the PLL\_EN bit (bit [31]) and the PLL\_LDO\_EN bit (bit [30]) of the PLL control register, write 0 to the PLL\_OUTPUT\_GATE bit (bit [27]) of the PLL control register.

**Step 3** Write 1 to the LOCK\_ENABLE bit (bit [29]) of the PLL control register.

**Step 4** Wait for the status of the Lock to change to 1.

**Step 5** Delay 20 us.

**Step 6** Write the PLL\_OUTPUT\_GATE bit (bit [27]) of the PLL control register to 1 and then the PLL will be available.

### 2.11.3.2 Configuring the Frequency of PLL\_AUDIO1

The frequency configuration formula of PLL\_AUDIO1:

$$\text{PLL\_AUDIO1} = 24 \text{ MHz} * N / M0 / M1 / P$$

PLL\_AUDIO1 does not support dynamic adjustment because changing any parameter of N, M0, M1, and P will affect the normal work of PLL, and the PLL will need to be relocked.

Generally, PLL\_AUDIO1 only needs two frequency points: 24.576\*4 MHz or 22.5792\*4 MHz. For these two frequencies, there are usually special recommended matching factors. To implement the desired frequency point of PLL\_AUDIO1, you need to use the decimal frequency-division function, so follow the steps below:

**Step 1** Configure the N, M0, M1 and P factors.

**Step 2** Write 1 to the PLL\_SDM\_EN bit (bit [24]) of [PLL\\_AUDIO1\\_CTRL](#) register.

**Step 3** Configure [PLL\\_AUDIO1\\_PAT0\\_CTRL](#) register to enable the digital spread spectrum.

**Step 4** Write 0 and then write 1 to the LOCK\_ENABLE bit (bit [29]) of [PLL\\_AUDIO1\\_CTRL](#) register.

**Step 5** Write 1 to the LOCK bit (bit [28]) of [PLL\\_AUDIO1\\_CTRL](#) register.

End



#### NOTE

When the P factor of PLL\_AUDIO1 is an odd number, the clock output is an unequal-duty-cycle signal.

### 2.11.3.3 Disabling the PLL

Follow the steps below to disable the PLL:

**Step 1** Write 0 to the PLL\_EN bit (bit [31]) and the PLL\_LDO\_EN bit (bit [30]) of the PLL control register.

**Step 2** Write 0 to the LOCK\_ENABLE bit (bit [29]) of the PLL control register.

### 2.11.3.4 Implementing Spread Spectrum

The spread spectrum technology is to convert a narrowband signal into a wideband signal. It helps to reduce the effect of electromagnetic interference (EMI) associated with the fundamental frequency of the signal.

For the general PLL frequency, the calculation formula is as follows:

$$f = \frac{N + 1 + X}{P \cdot (M_0 + 1) \cdot (M_1 + 1)} \cdot 24\text{MHz}, \quad 0 < X < 1$$

Where,

P is the frequency division factor of module or PLL;

M<sub>0</sub> is the post-frequency division factor of PLL;

M<sub>1</sub> is the pre-frequency division factor of PLL;

N is the frequency doubling factor of PLL;

X is the amplitude coefficient of the spread spectrum.

The parameters N, P, M<sub>1</sub>, and M<sub>0</sub> are for the frequency division.

When M<sub>1</sub> = 0, M<sub>0</sub> = 0, and P = 1 (no frequency division), the calculation formula of PLL frequency can be simplified as follows:

$$f = (N + 1 + X) \cdot 24\text{MHz}, \quad 0 < X < 1$$

$$[f_1, f_2] = (N + 1 + [X_1, X_2]) \cdot 24\text{MHz}$$

$$\text{SDM\_BOT} = 2^{17} \cdot X_1$$

$$\text{WAVE\_STEP} = 2^{17} \cdot (X_2 - X_1) / (24\text{MHz} / \text{PREQ}) \cdot 2$$

Where, SDM\_BOT and WAVE\_STEP are bits of the PLL pattern control register, and PREQ is the frequency of the spread spectrum.

Follow the steps below to implement the spread spectrum:

**Step 1** Configure the control register of the corresponding PLL

- a) Calculate the factor N and decimal value X according to the PLL frequency and PLL frequency formula. Refer to the control register of the corresponding PLL (named PLL\_xxx\_CTRL\_REG, where xxx is the module name) in 3.3.6 Register Description for the corresponding PLL frequency formula.
- b) Write M<sub>0</sub>, M<sub>1</sub>, N, and PLL frequency to the PLL control register.
- c) Configure the PLL\_SDM\_EN bit (bit [24]) of the PLL control register to 1 to enable the spread spectrum function.

**Step 2** Configure the pattern control register of the corresponding PLL

- a) Calculate the SDM\_BOT and WAVE\_STEP of the pattern control register according to decimal value X and spread spectrum frequency (the bit [18:17] of the PLL pattern register)

- b) Configure the spread spectrum mode (SPR\_FREQ\_MODE) to 2 or 3.
- c) If the PLL\_INPUT\_DIV2 of the PLL control register is 1, configure the spread spectrum clock source select bit (SDM\_CLK\_SEL) of the PLL pattern control register to 1. Otherwise, configure SDM\_CLK\_SEL to the default value 0.
- d) Write SDM\_BOT, WAVE\_STEP, PREQ, SPR\_FREQ\_MODE, and SDM\_CLK\_SEL to the PLL pattern control register, and configure the SIG\_DELT\_PAT\_EN bit (bit[31]) of this register to 1.

**Step 3** Delay 20 us

#### 2.11.3.5 Configuring Bus Clock

The bus clock supports dynamic switching, but the process of switching needs to follow the following two rules.

- From a higher frequency to a lower frequency: switch the clock source first, and then set the frequency division factor;
- From a lower frequency to a higher frequency: configure the frequency division factor first, and then switch the clock source.

The typical bus frequency for each bus in PRCM and MCU\_PRCM is as follows:

- AHBS: 200 MHz
- APBS0: 100 MHz
- APBS1: 24 MHz

#### 2.11.3.6 Configuring Module Clock

For the Bus Gating Reset register of a module, the reset bit is de-asserted first, and then the clock gating bit is enabled to avoid potential problems caused by the asynchronous release of the reset signal.

For all module clocks except the DDR clock, configure the clock source and frequency division factor first, and then release the clock gating (that is, set to 1). For the configuration order of the clock source and frequency division factor, follow the rules below:

- With the increasing of the clock source frequency, configure the frequency division factor before the clock source.
- With the decreasing of the clock source frequency, configure the clock source before the frequency division factor.

### 2.11.4 Register List

PRCM module includes two groups of registers:

| Module Name | Base Address |
|-------------|--------------|
|-------------|--------------|

| Module Name | Base Address |
|-------------|--------------|
| PRCM        | 0x0701 0000  |
| MCU_PRCM    | 0x0710 2000  |

#### 2.11.4.1 PRCM Register List

| Module Name | Base Address |
|-------------|--------------|
| PRCM        | 0x0701 0000  |

| Register Name             | Offset | Description                           |
|---------------------------|--------|---------------------------------------|
| AHBS_CFG_REG              | 0x0000 | AHBS Configuration Register           |
| APBS0_CFG_REG             | 0x000C | APBS0 Configuration Register          |
| APBS1_CFG_REG             | 0x0010 | APBS1 Configuration Register          |
| CPUS_TIMER0_CLK_REG       | 0x0100 | CPUS_TIMER0 Clock Register            |
| CPUS_TIMER1_CLK_REG       | 0x0104 | CPUS_TIMER1 Clock Register            |
| CPUS_TIMER2_CLK_REG       | 0x0108 | CPUS_TIMER2 Clock Register            |
| CPUS_TIMER_BGR_REG        | 0x011C | CPUS_TIMER Bus Gating Reset Register  |
| S_TWD_BGR_REG             | 0x012C | S_TWD Bus Gating Reset Register       |
| S_PWMCTRL_CLK_REG         | 0x0130 | S_PWMCTRL Clock Register              |
| S_PWMCTRL_BGR_REG         | 0x013C | S_PWMCTRL Bus Gating Reset Register   |
| S_SPI_CLK_REG             | 0x0150 | S_SPI Clock Register                  |
| S_SPI_BGR_REG             | 0x015C | S_SPI Bus Gating Reset Register       |
| S_SPINLOCK_BGR_REG        | 0x016C | S_SPINLOCK Bus Gating Reset Register  |
| CPUS_MSGBOX_BGR_REG       | 0x017C | CPUS_MSGBOX Bus Gating Reset Register |
| S_UART_BGR_REG            | 0x018C | S_UART Bus Gating Reset Register      |
| S_TWI_BGR_REG             | 0x019C | S_TWI Bus Gating Reset Register       |
| S_PPU_BGR_REG             | 0x01AC | S_PPU Bus Gating Reset Register       |
| S_CPUS_BIST_BGR_REG       | 0x01BC | S_CPUS_BIST Bus Gating Reset Register |
| S_IRRX_CLK_REG            | 0x01C0 | S_IRRX Clock Register                 |
| S_IRRX_BGR_REG            | 0x01CC | S_IRRX Bus Gating Reset Register      |
| DMA_ADB400_CLKEN_REG      | 0x01DC | DMA ADB400 Gating Register            |
| RTC_BGR_REG               | 0x020C | RTC Bus Gating Reset Register         |
| S_CPUFCFG_BGR_REG         | 0x022C | S_CPUFCFG Bus Gating Reset Register   |
| PLL_CTRL_REG0             | 0x0240 | PLL Control Register 0                |
| PLL_CTRL_REG1             | 0x0244 | PLL Control Register 1                |
| VDD_SYS_PWROFF_GATING_REG | 0x0250 | VDD_SYS Power Off Gating Register     |
| ANA_PWR_RST_REG           | 0x0254 | Analog Power Off Gating Register      |
| VDD_SYS_PWR_RST_REG       | 0x0260 | VDD_SYS Power Domain Reset Register   |
| MCU_SYS_PWR_RST_REG       | 0x0264 | MCU_SYS Power Domain Reset Register   |
| RAM1P_CFG_REG             | 0x0270 | RAM1P Configuration Register          |
| RAM2P_CFG_REG             | 0x0274 | RAM2P Configuration Register          |

| Register Name          | Offset | Description                            |
|------------------------|--------|----------------------------------------|
| RAMSP_CFG_REG          | 0x0278 | RAMSP Configuration Register           |
| ROM_CFG_REG            | 0x027C | ROM Configuration Register             |
| NMI_INT_CTRL_REG       | 0x0320 | NMI Interrupt Control Register         |
| NMI_INT_EN_REG         | 0x0324 | NMI Interrupt Enable Register          |
| NMI_INT_PEND_REG       | 0x0328 | NMI Interrupt Pending Register         |
| DEV_BUS_AUTOG_CTRL_REG | 0x0338 | DEV_BUS_AUTOG_CTRL_REG Register        |
| BUS_ACG_REG            | 0x033C | Bus Auto Clock Gating Register         |
| MSRAMOC_CTRL_REG       | 0x0360 | MSRAMOC Control Register               |
| REMAP_CTRL_REG         | 0x0364 | REMAP Control Register                 |
| AHBS_RDY_TOUT_CTRL_REG | 0x0368 | AHBS Ready Timeout Control Register    |
| CPUS_DEV_DMA_SEL_REG   | 0x0370 | CPUS Device DMA Configuration Register |
| CRY_CONFIG_REG         | 0x03E0 | Crypt Configuration Register           |
| CRY_KEY_REG            | 0x03E4 | Crypt Key Register                     |
| CRY_EN_REG             | 0x03E8 | Crypt Enable Register                  |

#### 2.11.4.2 MCU\_PRCM Register List

| Module Name | Base Address |
|-------------|--------------|
| MCU_PRCM    | 0x0710 2000  |

| Register Name            | Offset | Description                          |
|--------------------------|--------|--------------------------------------|
| PLL_CTRL_REG0            | 0x0000 | PLL Control Register0                |
| PLL_CTRL_REG1            | 0x0004 | PLL Control Register 1               |
| PLL_AUDIO1_CTRL_REG      | 0x000C | PLL_AUDIO1 Control Register          |
| PLL_AUDIO1_PAT0_CTRL_REG | 0x0010 | PLL_AUDIO1 Pattern0 Control Register |
| PLL_AUDIO1_PAT1_CTRL_REG | 0x0014 | PLL_AUDIO1 Pattern1 Control Register |
| PLL_AUDIO1_BIAS_REG      | 0x0018 | PLL_AUDIO1 Bias Register             |
| AUD_CLK_REG              | 0x001C | Audio Out Clock Register             |
| I2S0_CLK_REG             | 0x002C | I2S0 Clock Register                  |
| I2S1_CLK_REG             | 0x0030 | I2S1 Clock Register                  |
| I2S2_CLK_REG             | 0x0034 | I2S2 Clock Register                  |
| I2S3_CLK_REG             | 0x0038 | I2S3 Clock Register                  |
| I2S3_ASRC_CLK_REG        | 0x003C | I2S3_ASRC Clock Register             |
| I2S_BGR_REG              | 0x0040 | I2S Bus Gating Reset Register        |
| OWA_TX_CLK_REG           | 0x0044 | OWA_TX Clock Register                |
| OWA_RX_CLK_REG           | 0x0048 | OWA_RX Clock Register                |
| OWA_BGR_REG              | 0x004C | OWA Bus Gating Reset Register        |
| DMIC_CLK_REG             | 0x0050 | DMIC Clock Register                  |
| DMIC_BGR_REG             | 0x0054 | DMIC Bus Gating Reset Register       |
| AUDIO_CODEC_DAC_CLK_REG  | 0x0058 | AUDIO_CODEC_DAC Clock Register       |

| Register Name              | Offset | Description                                   |
|----------------------------|--------|-----------------------------------------------|
| AUDIO_CODEC_ADC_CLK_REG    | 0x005C | AUDIO_CODEC_ADC Clock Register                |
| AUDIO_CODEC_BGR_REG        | 0x0060 | AUDIO_CODEC Bus Gating Reset Register         |
| AHBS_RDY_TOUT_CTRL_REG     | 0x0064 | AHBS Ready Timeout Control Register           |
| MCU_TIMER0_CLK_REG         | 0x0074 | MCU_TIMER0 Clock Register                     |
| MCU_TIMER1_CLK_REG         | 0x0078 | MCU_TIMER1 Clock Register                     |
| MCU_TIMER2_CLK_REG         | 0x007C | MCU_TIMER2 Clock Register                     |
| MCU_TIMER3_CLK_REG         | 0x0080 | MCU_TIMER3 Clock Register                     |
| MCU_TIMER4_CLK_REG         | 0x0084 | MCU_TIMER4 Clock Register                     |
| MCU_TIMER5_CLK_REG         | 0x0088 | MCU_TIMER5 Clock Register                     |
| MCU_TIMER_BUS_BGR_REG      | 0x008C | MCU_TIMER Bus Gating Reset Register           |
| MCU_DMAC_BGR_REG           | 0x0104 | MCU_DMAC Bus Gating Reset Register            |
| PUBSRAM_BGR_REG            | 0x0114 | PUBSRAM Bus Gating Reset Register             |
| AHBS1_RDY_TOUT_CTRL_REG    | 0x0118 | AHBS1 Ready Timeout Control Register          |
| MCLK_GATING_CFG_REG        | 0x011C | MCLK Gating Configuration Register            |
| RISCV_CLK_REG              | 0x0120 | RISCV Clock Register                          |
| RISCV_CFG_BGR_REG          | 0x0124 | RISCV Configuration Bus Gating Reset Register |
| RISCV_MSGBOX_BGR_REG       | 0x0128 | RISCV MSGBOX Bus Gating Reset Register        |
| MCU_PWMCTRL_CLK_REG        | 0x0130 | MCU_PWMCTRL Clock Register                    |
| MCU_PWMCTRL_BGR_REG        | 0x0134 | MCU_PWMCTRL Bus Gating Reset Register         |
| PLL_BACKDOOR_OUTPUT_EN_REG | 0x0160 | PLL Backdoor Output Enable Register           |
| TEST_DBG_REG               | 0x0164 | Test Debug Register                           |

## 2.11.5 PRCM Register Description

### 2.11.5.1 0x0000 AHBS Configuration Register (Default Value: 0x0000\_0000)

| Offset: 0x0000 |     |             | Register Name: AHBS_CFG_REG                                                                                                                                                              |
|----------------|-----|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                                                                                                                                                              |
| 31:27          | /   | /           | /                                                                                                                                                                                        |
| 26:24          | R/W | 0x0         | AHBS_CLK_SRC_SEL<br>AHBS Clock Source Selection<br>000: CLK24M<br>001: CLK32K<br>010: CLK_RC<br>011: PERIPLL_DIV = PERIOPLL1X/3<br>100: AUDIO1PLL4X<br>Others: /<br>CLK = Clock Source/M |
| 23:5           | /   | /           | /                                                                                                                                                                                        |

| Offset: 0x0000 |     |             | Register Name: AHBS_CFG_REG                                        |
|----------------|-----|-------------|--------------------------------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                                        |
| 4:0            | R/W | 0x0         | FACTOR_M<br>Factor M<br>M= FACTOR_M +1<br>FACTOR_M is from 0 to 31 |

#### 2.11.5.2 0x000C APBS0 Configuration Register (Default Value: 0x0000\_0000)

| Offset: 0x000C |     |             | Register Name: APBS0_CFG_REG                                                                                                                                                             |
|----------------|-----|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                                                                                                                                                              |
| 31:27          | /   | /           | /                                                                                                                                                                                        |
| 26:24          | R/W | 0x0         | APBS0_CLK_SRC_SEL<br>APBS0 Clock Source Selection<br>000: CLK24M<br>001: CLK32K<br>010: CLK_RC<br>011: PERIPLL_DIV=PERIOPLL1X/3<br>100: AUDIO1PLL4X<br>Others: /<br>CLK = Clock Source/M |
| 23:5           | /   | /           | /                                                                                                                                                                                        |
| 4:0            | R/W | 0x0         | FACTOR_M<br>Factor M<br>M= FACTOR_M +1<br>FACTOR_M is from 0 to 31.                                                                                                                      |

#### 2.11.5.3 0x0010 APBS1 Configuration Register (Default: 0x0000\_0000)

| Offset: 0x0010 |     |             | Register Name: APBS1_CFG_REG                                                                                                                                                               |
|----------------|-----|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                                                                                                                                                                |
| 31:27          | /   | /           | /                                                                                                                                                                                          |
| 26:24          | R/W | 0x0         | APBS1_CLK_SRC_SEL<br>APBS1 Clock Source Selection<br>000: CLK24M<br>001: CLK32K<br>010: CLK_RC<br>011: PERIPLL_DIV = PERIOPLL1X/3<br>100: AUDIO1PLL4X<br>Others:/<br>CLK = Clock Source/ M |
| 23:5           | /   | /           | /                                                                                                                                                                                          |

| Offset: 0x0010 |     |             | Register Name: APBS1_CFG_REG                                       |
|----------------|-----|-------------|--------------------------------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                                        |
| 4:0            | R/W | 0x0         | FACTOR_M<br>Factor M (M= FACTOR_M +1)<br>FACTOR_M is from 0 to 31. |

#### 2.11.5.4 0x0100 CPUS\_TIMER0 Clock Register (Default: 0x0000\_0000)

| Offset: 0x0100 |     |             | Register Name: CPUS_TIMER0_CLK_REG                                                                                                                                                           |
|----------------|-----|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                                                                                                                                                                  |
| 31:7           | /   | /           | /                                                                                                                                                                                            |
| 6:4            | R/W | 0x0         | CLK_SRC_SEL.<br>CPUS_TIMER0 Clock Source Selection.<br>000: CLK24M<br>001: CLK32K<br>010: CLK_RC<br>011: PERIPLL_DIV=PERIOPLL1X/3<br>100: AUDIO1PLL4X<br>CPUS_TIMER0_CLK = Clock Source / N. |
| 3:1            | R/W | 0x0         | CPUS_TIMER0_CLK_DIVN.<br>Select the pre-scale of CPUS_TIMER0 clock source.<br>Factor N<br>000: /1<br>001: /2<br>010: /4<br>011: /8<br>100: /16<br>101: /32<br>110: /64<br>111: /128          |
| 0              | R/W | 0x0         | CPUS_TIMER0_CLK_GATING<br>0: Disable<br>1: Enable                                                                                                                                            |

#### 2.11.5.5 0x0104 CPUS\_TIMER1 Clock Register (Default: 0x0000\_0000)

| Offset: 0x0104 |     |             | Register Name: CPUS_TIMER1_CLK_REG                               |
|----------------|-----|-------------|------------------------------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                                      |
| 31:7           | /   | /           | /                                                                |
| 6:4            | R/W | 0x0         | CLK_SRC_SEL<br>CPUS_TIMER1 Clock Source Selection<br>000: CLK24M |

| Offset: 0x0104 |     |             | Register Name: CPUS_TIMER1_CLK_REG                                                                                                                                                 |
|----------------|-----|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                                                                                                                                                        |
|                |     |             | 001: CLK32K<br>010: CLK_RC<br>011: PERIPLL_DIV=PERI0PLL1X/3<br>100: AUDIO1PLL4X<br>CPUS_TIMER1_CLK = Clock Source/N                                                                |
| 3:1            | R/W | 0x0         | CPUS_TIMER1_CLK_DIVN<br>Select the pre-scale of CPUS_TIMER1 clock source.<br>Factor N<br>000: /1<br>001: /2<br>010: /4<br>011: /8<br>100: /16<br>101: /32<br>110: /64<br>111: /128 |
| 0              | R/W | 0x0         | CPUS_TIMER1_CLK_GATING<br>0: Disable<br>1: Enable                                                                                                                                  |

#### 2.11.5.6 0x0108 CPUS\_TIMER2 Clock Register (Default: 0x0000\_0000)

| Offset: 0x0108 |     |             | Register Name: CPUS_TIMER2_CLK_REG                                                                                                                                                      |
|----------------|-----|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                                                                                                                                                             |
| 31:7           | /   | /           | /                                                                                                                                                                                       |
| 6:4            | R/W | 0x0         | CLK_SRC_SEL<br>CPUS_TIMER2 Clock Source Selection<br>000: CLK24M<br>001: CLK32K<br>010: CLK_RC<br>011: PERIPLL_DIV=PERI0PLL1X/3<br>100: AUDIO1PLL4X<br>CPUS_TIMER2_CLK = Clock Source/N |
| 3:1            | R/W | 0x0         | CPUS_TIMER2_CLK_DIVN<br>Select the pre-scale of CPUS_TIMER2 clock source.<br>Factor N<br>000: /1<br>001: /2<br>010: /4<br>011: /8<br>100: /16                                           |

| Offset: 0x0108 |     |             | Register Name: CPUS_TIMER2_CLK_REG                |
|----------------|-----|-------------|---------------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                       |
|                |     |             | 101: /32<br>110: /64<br>111: /128                 |
| 0              | R/W | 0x0         | CPUS_TIMER2_CLK_GATING<br>0: Disable<br>1: Enable |

#### 2.11.5.7 0x011C CPUS\_TIMER BUS GATING RESET Register (Default Value: 0x0000\_0000)

| Offset: 0x011C |            |             | Register Name: CPUS_TIMER_BGR_REG                                      |
|----------------|------------|-------------|------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                            |
| 31:17          | /          | /           | /                                                                      |
| 16             | R/W        | 0x0         | CPUS_TIMER_RST<br>CPUS_TIMER Reset<br>0: Assert<br>1: De-assert        |
| 15:1           | /          | /           | /                                                                      |
| 0              | R/W        | 0x0         | CPUS_TIMER_GATING<br>Gating Clock for CPUS_TIMER<br>0: Mask<br>1: Pass |

#### 2.11.5.8 0x012C S\_TWD BUS GATING RESET Register (Default Value: 0x0000\_0001)

| Offset: 0x012C |            |             | Register Name: S_TWD_BGR_REG                                 |
|----------------|------------|-------------|--------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                  |
| 31:1           | /          | /           | /                                                            |
| 0              | R/W        | 0x1         | S_TWD_GATING<br>Gating Clock for S_TWD<br>0: Mask<br>1: Pass |

#### 2.11.5.9 0x0130 S\_PWMCTRL Clock Register (Default: 0x0000\_0000)

| Offset: 0x0130 |            |             | Register Name: S_PWMCTRL_CLK_REG                                |
|----------------|------------|-------------|-----------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                     |
| 31             | R/W        | 0x0         | S_PWMCTRL_CLK_GATING<br>Gating Special Clock<br>0: Clock is OFF |

| Offset: 0x0130 |            |             | Register Name: S_PWMCTRL_CLK_REG                                                                                                                                                                                           |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                |
|                |            |             | 1: Clock is ON<br>S_PWMCTRL_CLK = Clock Source                                                                                                                                                                             |
| 30:26          | /          | /           | /                                                                                                                                                                                                                          |
| 25:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Selection<br>00: CLK24M<br>01: CLK32K<br>10: CLK_RC<br>11:/<br>CLK32K is generated by calibrated CLK_RC or external low speed crystal. For more information, please refer to section 2.12 RTC. |
| 23:0           | /          | /           | /                                                                                                                                                                                                                          |

#### 2.11.5.10 0x013C S\_PWMCTRL BUS GATING RESET Register (Default: 0x0000\_0000)

| Offset: 0x013C |            |             | Register Name: S_PWMCTRL_BGR_REG                                         |
|----------------|------------|-------------|--------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                              |
| 31:17          | /          | /           | /                                                                        |
| 16             | R/W        | 0x0         | S_PWMCTRL_RST<br>S_PWMCTRL Reset<br>0: Assert<br>1: De-assert            |
| 15:1           | /          | /           | /                                                                        |
| 0              | R/W        | 0x0         | S_PWMCTRL_GATING<br>Gating bus Clock for S_PWMCTRL<br>0: Mask<br>1: Pass |

#### 2.11.5.11 0x0150 S\_SPI0 Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0150 |     |             | Register Name: S_SPI0_CLK_REG                                                                            |
|----------------|-----|-------------|----------------------------------------------------------------------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                                                                              |
| 31             | R/W | 0x0         | SCLK_GATING<br>Gating Special Clock<br>0: Clock is OFF<br>1: Clock is ON<br>R_SPI_CLK = Clock Source/M/N |
| 30:27          | /   | /           | /                                                                                                        |
| 26:24          | R/W | 0x0         | SPI_CLK_SRC_SEL                                                                                          |

| Offset: 0x0150 |     |             | Register Name: S_SPI0_CLK_REG                                                                                                        |
|----------------|-----|-------------|--------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                                                                                                          |
|                |     |             | SPI Clock Source Selection<br>000: CLK24M<br>001: PERIPLL_DIV=PERI0PLL1X/3<br>010: PERI0_300M<br>011: PERI1_300M<br>100: AUDIO1PLL4X |
| 23:13          | /   | /           | /                                                                                                                                    |
| 12:8           | R/W | 0x0         | FACTOR_N<br>Factor N<br>N= FACTOR_N +1<br>FACTOR_N is from 0 to 31.                                                                  |
| 7:5            | /   | /           | /                                                                                                                                    |
| 4:0            | R/W | 0x0         | FACTOR_M<br>Factor M<br>M= FACTOR_M +1<br>FACTOR_M is from 0 to 31.                                                                  |

#### 2.11.5.12 0x015C S\_SPI0 BUS GATING RESET Register (Default: 0x0000\_0000)

| Offset: 0x015C |            |             | Register Name: S_SPI0_BGR_REG                                  |
|----------------|------------|-------------|----------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                    |
| 31:17          | /          | /           | /                                                              |
| 16             | R/W        | 0x0         | S_SPI0_RST<br>S_SPI0 Reset<br>0: Assert<br>1: De-assert        |
| 15:1           | /          | /           | /                                                              |
| 0              | R/W        | 0x0         | S_SPI0_GATING<br>Gating Clock for S_SPI0<br>0: Mask<br>1: Pass |

#### 2.11.5.13 0x016C S\_SPINLOCK BUS GATING RESET Register (Default: 0x0000\_0000)

| Offset: 0x016C |            |             | Register Name: S_SPINLOCK_BGR_REG               |
|----------------|------------|-------------|-------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                     |
| 31:17          | /          | /           | /                                               |
| 16             | R/W        | 0x0         | S_SPINLOCK_RST<br>S_SPINLOCK Reset<br>0: Assert |

| Offset: 0x016C |            |             | Register Name: S_SPINLOCK_BGR_REG                                      |
|----------------|------------|-------------|------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                            |
|                |            |             | 1: De-assert                                                           |
| 15:1           | /          | /           | /                                                                      |
| 0              | R/W        | 0x0         | S_SPINLOCK_GATING<br>Gating Clock for S_SPINLOCK<br>0: Mask<br>1: Pass |

#### 2.11.5.14 0x017C CPUS\_MSGBOX BUS GATING RESET Register (Default: 0x0000\_0000)

| Offset: 0x017C |            |             | Register Name: CPUS_MSGBOX_BGR_REG                                       |
|----------------|------------|-------------|--------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                              |
| 31:17          | /          | /           | /                                                                        |
| 16             | R/W        | 0x0         | CPUS_MSGBOX_RST<br>CPUS_MSGBOX Reset<br>0: Assert<br>1: De-assert        |
| 15:1           | /          | /           | /                                                                        |
| 0              | R/W        | 0x0         | CPUS_MSGBOX_GATING<br>Gating Clock for CPUS_MSGBOX<br>0: Mask<br>1: Pass |

#### 2.11.5.15 0x018C S\_UART BUS GATING RESET Register (Default: 0x0000\_0000)

| Offset: 0x018C |            |             | Register Name: S_UART_BGR_REG                                    |
|----------------|------------|-------------|------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                      |
| 31:18          | /          | /           | /                                                                |
| 17             | R/W        | 0x0         | S_UART1_RST<br>S_UART1 Reset<br>0: Assert<br>1: De-assert        |
| 16             | R/W        | 0x0         | S_UART0_RST<br>S_UART0 Reset<br>0: Assert<br>1: De-assert        |
| 15:2           | /          | /           | /                                                                |
| 1              | R/W        | 0x0         | S_UART1_GATING<br>Gating Clock for S_UART1<br>0: Mask<br>1: Pass |

| Offset: 0x018C |            |             | Register Name: S_UART_BGR_REG                                    |
|----------------|------------|-------------|------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                      |
| 0              | R/W        | 0x0         | S_UART0_GATING<br>Gating Clock for S_UART0<br>0: Mask<br>1: Pass |

#### 2.11.5.16 0x019C S\_TWI BUS GATING RESET Register (Default: 0x0000\_0000)

| Offset: 0x019C |            |             | Register Name: S_TWI_BGR_REG                                   |
|----------------|------------|-------------|----------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                    |
| 31:19          | /          | /           | /                                                              |
| 18             | R/W        | 0x0         | S_TWI2_RST<br>S_TWI2 Reset<br>0: Assert<br>1: De-assert        |
| 17             | R/W        | 0x0         | S_TWI1_RST<br>R_TWI1 Reset<br>0: Assert<br>1: De-assert        |
| 16             | R/W        | 0x0         | S_TWI0_RST<br>R_TWI0 Reset<br>0: Assert<br>1: De-assert        |
| 15:3           | /          | /           | /                                                              |
| 2              | R/W        | 0x0         | S_TWI2_GATING<br>Gating Clock for S_TWI2<br>0: Mask<br>1: Pass |
| 1              | R/W        | 0x0         | S_TWI1_GATING<br>Gating Clock for S_TWI1<br>0: Mask<br>1: Pass |
| 0              | R/W        | 0x0         | S_TWI0_GATING<br>Gating Clock for S_TWI0<br>0: Mask<br>1: Pass |

#### 2.11.5.17 0x01AC S\_PPU BUS GATING RESET Register (Default Value: 0x0001\_0001)

| Offset: 0x01AC |            |             | Register Name: S_PPU_BGR_REG |
|----------------|------------|-------------|------------------------------|
| Bit            | Read/Write | Default/Hex | Description                  |

| Offset: 0x01AC |            |             | Register Name: S_PPU_BGR_REG                                         |
|----------------|------------|-------------|----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                          |
| 31:18          | /          | /           | /                                                                    |
| 17             | R/W        | 0x0         | S_PPU1_RST<br>S_PPU1 Reset<br>0: Assert<br>1: De-assert              |
| 16             | R/W        | 0x1         | Reserved                                                             |
| 15:2           | /          | /           | /                                                                    |
| 1              | R/W        | 0x0         | S_PPU1_GATING<br>Gating Clock for S_PPU1<br>0: Mask<br>1: Pass       |
| 0              | R/W        | 0x1         | S_PPU_GATING<br>Gating Clock for S_PPU(PCK600)<br>0: Mask<br>1: Pass |

#### 2.11.5.18 0x01BC S\_CPUS\_BIST BUS GATING RESET Register (Default Value: 0x0000\_0000)

| Offset: 0x01BC |            |             | Register Name: S_CPUS_BIST_BGR_REG                                       |
|----------------|------------|-------------|--------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                              |
| 31:1           | /          | /           | /                                                                        |
| 0              | R/W        | 0x0         | S_CPUS_BIST_GATING<br>Gating Clock for S_CPUS_BIST<br>0: Mask<br>1: Pass |

#### 2.11.5.19 0x01C0 S\_IRRX Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x01C0 |            |             | Register Name: S_IRRX_CLK_REG                                                                           |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                             |
| 31             | R/W        | 0x0         | SCLK_GATING<br>Gating Special Clock<br>0: Clock is OFF<br>1: Clock is ON<br>S_IRRX_CLK = Clock Source/M |
| 30:26          | /          | /           | /                                                                                                       |
| 25:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Selection<br>00: CLK32K<br>01: CLK24M                                       |

| Offset: 0x01C0 |            |             | Register Name: S_IRRX_CLK_REG                                       |
|----------------|------------|-------------|---------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                         |
|                |            |             | 10:/<br>11:/                                                        |
| 23:5           | /          | /           | /                                                                   |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M= FACTOR_M +1<br>FACTOR_M is from 0 to 31. |

#### 2.11.5.20 0x01CC S\_IRRX BUS GATING RESET Register (Default Value: 0x0000\_0000)

| Offset: 0x01CC |            |             | Register Name: S_IRRX_BGR_REG                                  |
|----------------|------------|-------------|----------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                    |
| 31:17          | /          | /           | /                                                              |
| 16             | R/W        | 0x0         | S_IRRX_RST<br>S_IRRX Reset<br>0: Assert<br>1: De-assert        |
| 15:1           | /          | /           | /                                                              |
| 0              | R/W        | 0x0         | S_IRRX_GATING<br>Gating Clock for S_IRRX<br>0: Mask<br>1: Pass |

#### 2.11.5.21 0x01DC DMA ADB400 GATING Register (Default Value: 0x0000\_0001)

| Offset: 0x01DC |            |             | Register Name: DMA_ADB400_CLKEN_REG                                   |
|----------------|------------|-------------|-----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                           |
| 31:1           | /          | /           | /                                                                     |
| 0              | R/W        | 0x1         | DMA_CLKEN_SW<br>Gating Clock for DMA ADB400 MST<br>0: Mask<br>1: Pass |

#### 2.11.5.22 0x020C RTC Bus Gating Reset Register (Default Value: 0x0001\_0001)

| Offset: 0x020C |            |             | Register Name: RTC_BGR_REG |
|----------------|------------|-------------|----------------------------|
| Bit            | Read/Write | Default/Hex | Description                |
| 31:17          | /          | /           | /                          |
| 16             | R/W        | 0x1         | RTC_RST                    |

| Offset: 0x020C |            |             | Register Name: RTC_BGR_REG                               |
|----------------|------------|-------------|----------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                              |
|                |            |             | RTC Reset<br>0: Assert<br>1: De-assert                   |
| 15:1           | /          | /           | /                                                        |
| 0              | R/W        | 0x1         | RTC_GATING<br>Gating Clock for RTC<br>0: Mask<br>1: Pass |

#### 2.11.5.23 0x022C S\_CPUCFG Bus Gating Reset Register (Default Value: 0x0001\_0001)

| Offset: 0x022C |            |             | Register Name: S_CPUCFG_BGR_REG                                    |
|----------------|------------|-------------|--------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                        |
| 31:17          | /          | /           | /                                                                  |
| 16             | R/W        | 0x1         | S_CPUCFG_RST<br>S_CPUCFG Reset<br>0: Assert<br>1: De-assert        |
| 15:1           | /          | /           | /                                                                  |
| 0              | R/W        | 0x1         | S_CPUCFG_GATING<br>Gating Clock for S_CPUCFG<br>0: Mask<br>1: Pass |

#### 2.11.5.24 0x0240 PLL Control Register 0 (Default Value: 0x0000\_0007)

| Offset: 0x0240 |     |             | Register Name: PLL_CTRL_REG0                                                       |
|----------------|-----|-------------|------------------------------------------------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                                                        |
| 31:25          | /   | /           | /                                                                                  |
| 24             | R/W | 0x0         | TEST_CLK_SEL<br>PLL Reference Clock Selection<br>0: DCXO<br>1: External Test Clock |
| 23:3           | /   | /           | /                                                                                  |
| 2              | R/W | 0x1         | GM1<br>XTAL Gain Control Bit1                                                      |
| 1              | R/W | 0x1         | GM0<br>XTAL Gain Control Bit0                                                      |
| 0              | R/W | 0x1         | Reserved                                                                           |

## 2.11.5.25 0x0244 PLL Control Register 1 (Default Value: 0x0004\_0005)

| Offset: 0x0244 |     |             | Register Name: PLL_CTRL_REG1                                                                                                                                                                                 |
|----------------|-----|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                                                                                                                                                                                  |
| 31:24          | R/W | 0x0         | KEY_FIELD<br>Key Field for LDO Enable bit<br>If the key field value is 0xA7, the bit[23:0] can be modified.                                                                                                  |
| 23:19          | /   | /           | /                                                                                                                                                                                                            |
| 18:16          | R/W | 0x4         | PLLVDD_LDO_OUT_CTRL<br>PLLVDD LDO Output Control<br>000: 0.82 V<br>001: 0.86 V<br>010: 0.9 V<br>011: 0.94v<br>100: 0.98v<br>101: 1.02v<br>110: 1.06v<br>111: 1.10v                                           |
| 15:5           | /   | /           | /                                                                                                                                                                                                            |
| 4              | R/W | 0x0         | MBIAS_EN<br>Chip Master Bias Enable<br>0: From Internal Bias<br>1: From ADDA Bias                                                                                                                            |
| 3              | R/W | 0x0         | PLLTEST_EN<br>For Verify (Back door clock PLLTEST enable)<br>0: Output clock is gated off.<br>1: Clock Output. The clock is the clock output to the PLL and the clock after frequency division through pins. |
| 2:1            | R/W | 0x2         | Reserved                                                                                                                                                                                                     |
| 0              | R/W | 0x1         | LDO_EN<br>LDO Enable<br>0: Disable<br>1: Enable<br>Note: PLL Power enable (power source from VCC_PLL).                                                                                                       |

## 2.11.5.26 0X0250 VDD\_SYS Power Off Gating Register (Default Value: 0x0000\_0000)

| Offset: 0x0250 |     |             | Register Name: VDD_SYS_PWROFF_GATING_REG |
|----------------|-----|-------------|------------------------------------------|
| Bit            | R/W | Default/Hex | Description                              |

| Offset: 0x0250 |     |             | Register Name: VDD_SYS_PWROFF_GATING_REG                                                                                                                                                                                                                                                                                               |
|----------------|-----|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                                                                                                                                                                                                                                                                                                            |
| 31:9           | /   | /           | /                                                                                                                                                                                                                                                                                                                                      |
| 8              | R/W | 0x0         | VDD_USB2CPUS_GATING<br>0: Invalid<br>1: Valid<br>To gate off the signal output to VDD-CPUS from USB module, set this bit to 1.                                                                                                                                                                                                         |
| 7:6            | /   | /           | /                                                                                                                                                                                                                                                                                                                                      |
| 5              | R/W | 0x0         | VDD_SYS2MCU_GATING<br>Gating the corresponding modules to the MCU module when VDD-SYS powers off.<br>0: Invalid<br>1: Valid<br>This bit should be set to 1 before VDD-SYS power off while it should be set to 0 after the VDD-SYS power on. MCU CLK Source should switch to Internal OSC or AUDIO1PLL before VDD-SYS Power Off Gating. |
| 4              | R/W | 0x0         | VDD_MCU2CPUS_GATING<br>Gating the corresponding modules to the CPUS module when MCU_SYS powers off.<br>0: Invalid<br>1: Valid<br>This bit should be set to 1 before MCU_SYS powers off while it should be set to 0 after the MCU_SYS power on.                                                                                         |
| 3              | R/W | 0x0         | VDD_SYS2USB_GATING<br>Gating the corresponding modules to the USB module when VDD_SYS power off.<br>0: Invalid<br>1: Valid<br>This bit should be set to 1 before VDD_SYS power off while it should be set to 0 after the VDD_SYS power on. USB CLK Source should switch to Internal OSC before VDD_SYS Power Off Gating.               |
| 2              | R/W | 0x0         | VDD_SYS2CPUS_GATING<br>Gating the corresponding modules to the CPUS Power Domain when VDD_SYS power off.<br>0: Invalid<br>1: Valid<br>This bit should be set to 1 before VDD_SYS power off while it should be set to 0 after the VDD_SYS power on. CPUS CLK Source should switch to Internal OSC                                       |

| Offset: 0x0250 |     |             | Register Name: VDD_SYS_PWROFF_GATING_REG                                                         |
|----------------|-----|-------------|--------------------------------------------------------------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                                                                      |
|                |     |             | before VDD_SYS Power Off Gating.                                                                 |
| 1              | /   | /           | /                                                                                                |
|                |     |             | VDD_DDR_GATING<br>0: valid (gate valid)<br>1: Invalid (gate invalid)                             |
| 0              | R/W | 0x0         | When DDR entrys into power-down (low voltage) self-refresh mode, this signal will fix CLKE to 0. |

#### 2.11.5.27 0x0254 ANALOG Power Off Gating Register (Default Value: 0x0000\_0005)

| Offset: 0x0254 |     |             | Register Name: ANA_PWR_RST_REG                                                                                                                                   |
|----------------|-----|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                                                                                                                                      |
|                |     |             | /                                                                                                                                                                |
| 31:4           | /   | /           | /                                                                                                                                                                |
|                |     |             | PWROFF_ANA_EN_CPU<br>Gating The CPU PLL ANA Module Input When CPU_SYS Is Power Off.<br>0: Invalid, not gating<br>1: Valid, gating                                |
| 3              | R/W | 0x0         | When system is cold start, this bit is default not gating, before using the relate ANA module, must set this bit to 0.<br>Relate ANA module: PLL                 |
|                |     |             | PWROFF_ANA_EN MCU<br>Gating The MCU SYS PLL ANA Module Input When MCU_SYS Is Power Off.<br>0: Invalid, not gating<br>1: Valid, gating                            |
| 2              | R/W | 0x1         | Note: When system is cold start, this bit is default gating, before using the related ANA module, must set this bit to 0.<br>Related ANA module: PLL/AUDIO CODEC |
|                |     |             | PWROFF_ANA_EN<br>Gating The PLL ANA Module Input When VDD Is Power Off.<br>0: Invalid, not gating<br>1: Valid, gating                                            |
| 1              | R/W | 0x0         | Note: When system is cold start, this bit is default not gating, before using the relate ANA module, must set this bit to 0.<br>Relate ANA module: PLL           |
| 0              | R/W | 0x1         | SYS_ANA_VDDON_CTRL                                                                                                                                               |

| Offset: 0x0254 |     |             | Register Name: ANA_PWR_RST_REG                                                                                                                                                                                                                                                                                                         |
|----------------|-----|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                                                                                                                                                                                                                                                                                                            |
|                |     |             | <p>Gating The System Domain ANA Module Input When VDD Is Power Off.</p> <p>0: Invalid, not gating<br/>1: Valid, gating</p> <p>Note: When system is cold start, this bit is default gating, before using the relate ANA module, must set this bit to 0.</p> <p>Relate ANA module:<br/>RES/RES_CAL_DCAP/GPADC/DSI/LVDS/LRADC/USB/CSI</p> |

#### 2.11.5.28 0x0260 VDD\_SYS Power Domain Reset Register (Default: 0x0000\_0001)

| Offset: 0x0260 |     |             | Register Name: VDD_SYS_PWR_RST_REG                                                                                              |
|----------------|-----|-------------|---------------------------------------------------------------------------------------------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                                                                                                     |
| 31:1           | /   | /           | /                                                                                                                               |
| 0              | R/W | 0x1         | <p>MODULE_RST</p> <p>VDD_SYS Power Domain Modules should be reset before VDD_SYS power on</p> <p>0: Assert<br/>1: De-assert</p> |

#### 2.11.5.29 0x0264 MCU\_SYS Power Domain Reset Register (Default: 0x0000\_0001)

| Offset: 0x0264 |     |             | Register Name: MCU_SYS_PWR_RST_REG                                                                                                 |
|----------------|-----|-------------|------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                                                                                                        |
| 31:1           | /   | /           | /                                                                                                                                  |
| 0              | R/W | 0x1         | <p>MCU_SYS_RSTN</p> <p>MCU_SYS Power Domain Modules should be reset before MCU_SYS power on.</p> <p>0: Assert<br/>1: De-assert</p> |

#### 2.11.5.30 0x0270 RAM1P Configuration Register (Default Value: 0x0000\_0413)

| Offset: 0x0270 |     |             | Register Name: RAM1P_CFG_REG               |
|----------------|-----|-------------|--------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                |
| 31:0           | R/W | 0x413       | RF1P_MEM<br>RF1P Configuration Information |

#### 2.11.5.31 0x0274 RAM2P Configuration Register (Default Value: 0x0000\_8421)

| Offset: 0x0274 |     |             | Register Name: RAM2P_CFG_REG               |
|----------------|-----|-------------|--------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                |
| 31:0           | R/W | 0x8421      | RF2P_MEM<br>RF2P Configuration Information |

#### 2.11.5.32 0x0278 RAMSP Configuration Register (Default Value: 0x0000\_0403)

| Offset: 0x0278 |     |             | Register Name: RAMSP_CFG_REG               |
|----------------|-----|-------------|--------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                |
| 31:0           | R/W | 0x403       | SRAM_MEM<br>SRAM Configuration Information |

#### 2.11.5.33 0x027C ROM Configuration Register (Default Value: 0x0000\_0015)

| Offset: 0x027C |     |             | Register Name: ROM_CFG_REG               |
|----------------|-----|-------------|------------------------------------------|
| Bit            | R/W | Default/Hex | Description                              |
| 31:0           | R/W | 0x15        | ROM_MEM<br>ROM Configuration Information |

#### 2.11.5.34 0x0320 NMI Interrupt Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0320 |     |             | Register Name: NMI_INT_CTRL_REG                                                                                                                                         |
|----------------|-----|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                                                                                                                                             |
| 31:2           | /   | /           | /                                                                                                                                                                       |
| 1:0            | R/W | 0x0         | NMI_SRC_TYPE<br>External NMI Interrupt Source Type<br>00: Low level sensitive<br>01: Negative edge triggered<br>10: High level sensitive<br>11: Positive edge sensitive |

#### 2.11.5.35 0x0324 NMI Interrupt Enable Register (Default Value: 0x8000\_0000)

| Offset: 0x0324 |     |             | Register Name: NMI_INT_EN_REG                                         |
|----------------|-----|-------------|-----------------------------------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                                           |
| 31             | R/W | 0x1         | NMI_INPUT_DET_EN<br>NMI Input Detect Enable<br>0: Disable<br>1:Enable |

| Offset: 0x0324 |     |             | Register Name: NMI_INT_EN_REG                                                                                |
|----------------|-----|-------------|--------------------------------------------------------------------------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                                                                                  |
| 30:1           | /   | /           | /                                                                                                            |
| 0              | R/W | 0x0         | NMIIRQ_SYS_EN<br>Interrupt NMI for CPUX Enable Bits<br>0: Interrupt is disabled.<br>1: Interrupt is enabled. |

#### 2.11.5.36 0x0328 NMI Interrupt Pending Register (Default Value: 0x0000\_0000)

| Offset: 0x0328 |       |             | Register Name: NMI_INT_PEND_REG                                                                                                                                                                                                                                                                   |
|----------------|-------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | R/W   | Default/Hex | Description                                                                                                                                                                                                                                                                                       |
| 31:1           | /     | /           | /                                                                                                                                                                                                                                                                                                 |
| 0              | R/W1C | 0x0         | NMI_IRQ_PEND<br>NMI IRQ Pending<br>Interrupt NMI Pending/Clear Bit. Set 1 to the bit will clear it.<br>(after first enabling NMI IRQ function, must set this bit to 1 to clear the unexpected pending once)<br>0: Corresponding interrupt is not pending<br>1: Corresponding interrupt is pending |

#### 2.11.5.37 0x0338 DEV\_BUS\_AUTOG\_CTRL Register (Default Value: 0x0000\_0000)

| Offset: 0x0338 |     |             | Register Name: DEV_BUS_AUTOG_CTRL                                                                                                                                                                                                            |
|----------------|-----|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                                                                                                                                                                                                                  |
| 31:24          | R/W | 0x0         | CPUCLK_REC_DLY_TIME<br>This bit indicates the delay time needed to respond to CPUS clock after responding to peripherals and bus clocks, when exiting LP mode. The unit is PRCM clock.<br>0=256 cycle<br>1=1 cycle<br>.....<br>255=255 cycle |
| 23:21          | /   | /           | /                                                                                                                                                                                                                                            |
| 20             | R/W | 0x0         | LPI_OUT_SYNC_EN<br>LPI Interface from CPUS to PRCM Enable<br>0: CPUS clock is synchronous with PRCM clock.<br>1: CPUS clock is asynchronous with PRCM clock.                                                                                 |
| 18:12          | /   | /           | /                                                                                                                                                                                                                                            |
| 11             | R/W | 0x0         | LPI_IF_EN                                                                                                                                                                                                                                    |

| Offset: 0x0338 |     |             | Register Name: DEV_BUS_AUTOG_CTRL                                                                                                                                                                                                                                                                             |
|----------------|-----|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                                                                                                                                                                                                                                                                                   |
|                |     |             | LPI Interface Between CPUS and PRCM Enable<br>0: Disable<br>1: Enable<br>When LPI is disabled, CPUS status will not be routed to PRCM.                                                                                                                                                                        |
| 10             | R/W | 0x0         | LPI_IN_SYNC_EN<br>LPI Interface from PRCM to CPUS Enable<br>0: CPUS clock is synchronous with PRCM clock.<br>1: CPUS clock is asynchronous with PRCM clock.                                                                                                                                                   |
| 9              | R/W | 0x0         | TT_AUTOGATE_EN<br>CPUS Ticktimer Auto Gating Enable<br>When this bit is enabled and PM_TT_O is high, the ticktimer clock will be gated on automatically.                                                                                                                                                      |
| 8              | R/W | 0x0         | CPU_ICACHE_AUTOGATE_EN<br>Clock (excludes ticktimer clock) Auto Gating Enable<br>0: Auto gating is disabled.<br>1: Auto gating is enabled.<br>When this bit is enabled and both of PM_CPU_O and PM_ICACHE_O are high simultaneously, the clocks of CPUS, ICACHE, QMEM, and PM will be gated on automatically. |
| 7              | R   | 0x0         | PM_TT_STAT<br>CPUS LP Interface Status<br>0: CPUS is in normal mode and the ticktimer clock is disable to be gated off<br>1: The ticktimer clock is able to be gated off.                                                                                                                                     |
| 6              | R   | 0x0         | PM_ICACHE_STAT<br>CPUS LP Interface Status<br>0: CPUS is in normal mode and the ICACHE clock is disable to be gated off<br>1: The ICACHE clock is able to be gated off.                                                                                                                                       |
| 5              | R   | 0x0         | PM_CPU_STAT<br>CPUS LP Interface Status<br>0: CPUS is in normal mode and the CPU clock is disable to be gated off.<br>1: The CPU clock is able to be gated off.                                                                                                                                               |
| 4              | R   | 0x1         | CACTIVE_STAT<br>LPI CACTIVE Status<br>0: CPUS is in low power mode.<br>1: CPUS is in normal mode.                                                                                                                                                                                                             |
| 3:1            | /   | /           | /                                                                                                                                                                                                                                                                                                             |

| Offset: 0x0338 |     |             | Register Name: DEV_BUS_AUTOG_CTRL                                                                                                                                                                                           |
|----------------|-----|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                                                                                                                                                                                                 |
| 0              | R/W | 0x0         | CPUS_CLKAUTG_EN<br>0: Auto gating is disabled.<br>1: Auto gating is enabled.<br>When MCU gets into sleep mode, auto gating signal will be generated and then every modul bus and work clock will be gated on automatically. |

#### 2.11.5.38 0x033C Bus Auto Clock Gating Register (Default Value: 0x0000\_0000)

| Offset: 0x033C |     |             | Register Name: BUS_ACG_REG                                                                                                                                                                                  |
|----------------|-----|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                                                                                                                                                                                 |
| 31:25          | /   | /           | /                                                                                                                                                                                                           |
| 24             | R/W | 0x0         | AHBS_AUTO_CLK_GATE_EN<br>AHBS Bus Auto Clock Gating Function Enable<br>1: Enable auto clock gate<br>0: Disable auto clock gate                                                                              |
| 23:7           | /   | /           | /                                                                                                                                                                                                           |
| 6              | R/W | 0x0         | CPUS_MSGBOX_ACG_MODE_EN<br>CPUS_MSGBOX Auto Clock Gating Mode Enable<br>If this bit is 1 and AHBS auto clock gating function is enable, CPUS_MSGBOX HCLK will also be closed when AHBS bus clock is closed. |
| 5              | R/W | 0x0         | S_SPINLOCK_ACG_MODE_EN<br>S_SPINLOCK Auto Clock Gating Mode Enable<br>If this bit is 1 and AHBS auto clock gating function is enable, S_SPINLOCK HCLK will also be closed when AHBS bus clock is closed.    |
| 4              | R/W | 0x0         | Reserved                                                                                                                                                                                                    |
| 3              | R/W | 0x0         | CPUS_TIMER_ACG_MODE_EN<br>CPUS_TIMER Auto Clock Gating Mode Enable<br>If this bit is 1 and AHBS auto clock gating function is enable, CPUS_TIMER HCLK will also be closed when AHBS bus clock is closed.    |
| 2              | R/W | 0x0         | MSRAM_ACG_MODE_EN<br>MSRAMOC Auto Clock Gating Mode Enable<br>If this bit is 1 and AHBS auto AW1890clock gating function is enable, MSRAMOC HCLK will close when AHBS bus clock close.                      |
| 1              | R/W | 0x0         | RTC_ACG_MODE_EN<br>RTC Auto Clock Gating Mode Enable<br>SYSRTC module auto clock gating mode enable, if                                                                                                     |

| Offset: 0x033C |     |             | Register Name: BUS_ACG_REG                                                                                                                                                                                 |
|----------------|-----|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                                                                                                                                                                                |
|                |     |             | this bit is 1 and AHBS auto clock gating function is enable, SYSRTC module hclk will close when AHBS bus clock close.                                                                                      |
| 0              | R/W | 0x0         | BM_ACG_MODE_EN<br>AHBS Bus Matrix Auto Clock Gating Mode Enable<br>If this bit is 1 and AHBS auto clock gating function is enable, AHBS bus matrix HCLK will also be closed when AHBS bus clock is closed. |

#### 2.11.5.39 0x360 MSRAMOC Control Register (Default: 0x0000\_0000)

| Offset: 0x360 |     |             | Register Name: MSRAMOC_CTRL_REG                                               |
|---------------|-----|-------------|-------------------------------------------------------------------------------|
| Bit           | R/W | Default/Hex | Description                                                                   |
| 31:2          | /   | /           | /                                                                             |
| 1             | R/W | 0x0         | MSRAMOC_PORT_HOLD_EN<br>MSRAMOC Port Hold Enable<br>0: Disable<br>1: Enable   |
| 0             | R/W | 0x0         | MSRAMOC_ACG_EN<br>MSRAMOC Auto Clock Gating Enable<br>0: Disable<br>1: Enable |

#### 2.11.5.40 0x364 REMAP Control Register (Default: 0x0000\_0001)

| Offset: 0x364 |     |             | Register Name: REMAP_CTRL_REG                                                                  |
|---------------|-----|-------------|------------------------------------------------------------------------------------------------|
| Bit           | R/W | Default/Hex | Description                                                                                    |
| 31:2          | /   | /           | /                                                                                              |
| 1             | R/W | 0x0         | SRAMA3_2_RAM_REMAP<br>0: SRAMA3_2 does not share for MCU_SYS<br>1: SRAMA3_2 shares for MCU_SYS |
| 0             | R/W | 0x1         | Reserved                                                                                       |

#### 2.11.5.41 0x0368 AHBS Ready Timeout Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0368 |       |             | Register Name: AHBS_RDY_TOUT_CTRL_REG |
|----------------|-------|-------------|---------------------------------------|
| Bit            | R/W   | Default/Hex | Description                           |
| 31:25          | /     | /           | /                                     |
| 24             | R/W1C | 0x0         | AHBS_RDY_TIMEOUT_IRQ_PEND             |

| Offset: 0x0368 |     |             | Register Name: AHBS_RDY_TOUT_CTRL_REG                                                                                                      |
|----------------|-----|-------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                                                                                                                |
|                |     |             | AHBS Hready Time Out IRQ Pending<br>Write 1 Clear                                                                                          |
| 23:9           | /   | /           | /                                                                                                                                          |
| 8              | R/W | 0x0         | AHBS_RDY_TIMEOUT_IRQ_EN<br>AHBS Hready Time Out IRQ Enable<br>1: IRQ Enable<br>0: IRQ Disable                                              |
| 7              | R/W | 0x0         | AHBS_TIMEOUT_INT_VAL_SEL<br>AHBS Time Out Interval Value Selection<br>0: interal_value* 2^10 + 2^10 -1<br>1: interal_value* 2^16 + 2^16 -1 |
| 6:1            | R/W | 0x0         | AHBS_TIMEOUT_CNT_INT_VAL<br>AHBS Time Out Counter Interval Value                                                                           |
| 0              | R/W | 0x0         | AHBS_RDY_TIMEOUT_EN<br>AHBS Hready Time Out Enable                                                                                         |

#### 2.11.5.42 0x0370 CPUS Device DMA Configuration Register (Default Value: 0x0000\_0000)

| Offset: 0x0370 |     |             | Register Name: CPUS_DEV_DMA_SEL_REG                              |
|----------------|-----|-------------|------------------------------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                                      |
| 31:5           | /   | /           | /                                                                |
| 4              | R/W | 0x0         | DMA_SPI_SEL<br>SPI DMA Selection<br>0: MCU DMA<br>1: SYS DMA     |
| 3              | R/W | 0x0         | DMA_UART1_SEL<br>UART1 DMA Selection<br>0: MCU DMA<br>1: SYS DMA |
| 2              | R/W | 0x0         | DMA_UART0_SEL<br>UART0 DMA Selection<br>0: MCU DMA<br>1: SYS DMA |
| 1              | R/W | 0x0         | DMA_TWI1_SEL<br>TWI1 DMA Selection<br>0: MCU DMA<br>1: SYS DMA   |
| 0              | R/W | 0x0         | DMA_TWI0_SEL<br>TWI0 DMA Selection<br>0: MCU DMA                 |

| Offset: 0x0370 |     |             | Register Name: CPUS_DEV_DMA_SEL_REG |
|----------------|-----|-------------|-------------------------------------|
| Bit            | R/W | Default/Hex | Description                         |
|                |     |             | 1: SYS DMA                          |

#### 2.11.5.43 0x0374 I2S0 PAD Selection Configuration Register (Default Value: 0x0000\_0000)

| Offset: 0x0374 |     |             | Register Name: I2S0_PAD_SEL_REG                                         |
|----------------|-----|-------------|-------------------------------------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                                             |
| 31:1           | /   | /           | /                                                                       |
| 0              | R/W | 0x0         | I2S0_PAD_SEL<br>I2S0 PAD Selection<br>0: Use CPUS PAD<br>1: Use SYS PAD |

#### 2.11.5.44 0x0378 DMIC PAD Selection Configuration Register (Default Value: 0x0000\_0000)

| Offset: 0x0378 |     |             | Register Name: DMIC_PAD_SEL_REG                                         |
|----------------|-----|-------------|-------------------------------------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                                             |
| 31:1           | /   | /           | /                                                                       |
| 0              | R/W | 0x0         | DMIC_PAD_SEL<br>DMIC PAD Selection<br>0: Use CPUS PAD<br>1: Use SYS PAD |

#### 2.11.5.45 0x03E0 Crypt Configuration Register (Default Value: 0x0000\_0000)

| Offset: 0x03E0 |     |             | Register Name: CRY_CONFIG_REG                                                                                                           |
|----------------|-----|-------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                                                                                                             |
| 31:16          | /   | /           | /                                                                                                                                       |
| 15:0           | R/W | 0x0         | KEY_FIELD<br>Key Field<br>If you want to read or write Crypt Key Register/Crypt Enable Register, you should write 0x1689 in these bits. |

#### 2.11.5.46 0x03E4 Crypt Key Register (Default Value: 0x0000\_0000)

| Offset: 0x03E4 |     |             | Register Name: CRY_KEY_REG |
|----------------|-----|-------------|----------------------------|
| Bit            | R/W | Default/Hex | Description                |
| 31:0           | R/W | 0x0         | CRY_KEY<br>Crypt Key       |

#### 2.11.5.47 0x03E8 Crypt Enable Register (Default Value: 0x0000\_0000)

| Offset: 0x03E8 |     |             | Register Name: CRY_EN_REG |
|----------------|-----|-------------|---------------------------|
| Bit            | R/W | Default/Hex | Description               |
| 31:1           | /   | /           | /                         |
| 0              | R/W | 0x0         | CRY_EN<br>Crypt Enable    |

### 2.11.6 MCU\_PRCM Register Description

#### 2.11.6.1 0x0000 PLL Control Register0 (Default Value: 0x0000\_0007)

| Offset: 0x0000 |     |             | Register Name: PLL_CTRL_REG0                                                         |
|----------------|-----|-------------|--------------------------------------------------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                                                          |
| 31:25          | /   | /           | /                                                                                    |
| 24             | R/W | 0x0         | TEST_CLK_SEL<br>PLL Reference Clock Selection<br>0: DCXO.<br>1: External Test Clock. |
| 23:3           | /   | /           | /                                                                                    |
| 2              | R/W | 0x1         | GM1<br>XTAL Gain Control Bit1                                                        |
| 1              | R/W | 0x1         | GM0.<br>XTAL Gain Control Bit0                                                       |
| 0              | R/W | 0x1         | Reserved                                                                             |

#### 2.11.6.2 0x0004 PLL Control Register 1 (Default Value: 0x0004\_0005)

| Offset: 0x0004 |     |             | Register Name: PLL_CTRL_REG1                                                                                                |
|----------------|-----|-------------|-----------------------------------------------------------------------------------------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                                                                                                 |
| 31:24          | R/W | 0x0         | KEY_FIELD<br>Key Field for LDO Enable<br>If the key field value is 0xA7, the bit[23:0] can be modified.                     |
| 23:19          | /   | /           | /                                                                                                                           |
| 18:16          | R/W | 0x4         | PLLVDD_LDO_OUT_CTRL<br>PLLVDD LDO Output Control<br>000: 0.90 V<br>001: 0.94 V<br>010: 0.98 V<br>011: 1.02 V<br>100: 1.06 V |

| Offset: 0x0004 |     |             | Register Name: PLL_CTRL_REG1                                                                                                                                                                                 |
|----------------|-----|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                                                                                                                                                                                  |
|                |     |             | 101: 1.10 V<br>110: 1.14 V<br>111: 1.18 V                                                                                                                                                                    |
| 15:5           | /   | /           | /                                                                                                                                                                                                            |
| 4              | R/W | 0x0         | MBIAS_EN<br>Chip Master Bias Enable<br>0: From Internal Bias<br>1: From ADDA Bias                                                                                                                            |
| 3              | R/W | 0x0         | PLLTEST_EN<br>For Verify (Back door clock PLLTEST enable)<br>0: Output clock is gated off.<br>1: Clock Output. The clock is the clock output to the PLL and the clock after frequency division through pins. |
| 2:1            | R/W | 0x2         | Reserved                                                                                                                                                                                                     |
| 0              | R/W | 0x1         | LDO_EN<br>LDO Enable<br>0: Disable<br>1: Enable<br>Note: PLL Power enable (power source from VCC_PLL).                                                                                                       |

#### 2.11.6.3 0x000C PLL\_AUDIO1 Control Register (Default Value: 0x4841\_7F00)

| Offset: 0x000C |            |             | Register Name: PLL_AUDIO1_CTRL_REG                                                                                                                                                                                                                                                                                                                                                                                                   |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 31             | R/W        | 0x0         | PLL_EN<br>PLL Enable<br>0: Disable<br>1: Enable<br>The PLL_AUDIO1 = 24 MHz*N/M<br>The PLL_AUDIO1 (DIV2) = 24 MHz*N/M /P0<br>The PLL_AUDIO1 (DIV5) = 24 MHz*N/M /P1<br>The working frequency range of 24 MHz/M*N is from 180 MHz to 3.5 GHz.<br>The default frequency of PLL_AUDIO1 is 3072 MHz.<br>The default frequency of PLL_AUDIO1 (DIV2) is 1536 MHz.<br>The default frequency of PLL_AUDIO1 (DIV5) is 614.4MHz(24.576 MHz*25). |
| 30             | R/W        | 0x1         | PLL_LDO_EN                                                                                                                                                                                                                                                                                                                                                                                                                           |

| Offset: 0x000C |            |             | Register Name: PLL_AUDIO1_CTRL_REG                                                                                                                     |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                            |
|                |            |             | LDO enable<br>0: Disable<br>1: Enable                                                                                                                  |
| 29             | R/W        | 0x0         | LOCK_ENABLE<br>Lock Enable<br>0: Disable<br>1: Enable                                                                                                  |
| 28             | R          | 0x0         | LOCK<br>PLL Lock Info<br>0: Unlocked<br>1: Locked (It indicates that the PLL has been stable.)<br>This bit is only valid when the bit[29] is set to 1. |
| 27             | R/W        | 0x1         | PLL_OUTPUT_GATE<br>PLL Output Gating Enable<br>0: Disable<br>1: Enable<br>This bit is used to control the output enable of PLL.                        |
| 26:25          | /          | /           | /                                                                                                                                                      |
| 24             | R/W        | 0x0         | PLL_SDM_EN<br>PLL SDM Enable<br>0: Disable<br>1: Enable<br>Enable spread spectrum and decimal division.                                                |
| 23             | /          | /           | /                                                                                                                                                      |
| 22:20          | R/W        | 0x4         | PLL_P1<br>PLL Output Div P1<br>P1=PLL_OUTPUT_DIV_P1 + 1<br>PLL_OUTPUT_DIV_P1 is from 0 to 7.                                                           |
| 19             | /          | /           | /                                                                                                                                                      |
| 18:16          | R/W        | 0x1         | PLL_P0<br>PLL Output Div P0<br>P0=PLL_OUTPUT_DIV_P0 + 1<br>PLL_OUTPUT_DIV_P0 is from 0 to 7.                                                           |
| 15:8           | R/W        | 0x7F        | PLL_FACTOR_N<br>PLL Factor N<br>N= PLL_FACTOR_N +1<br>PLL_FACTOR_N is from 0 to 254<br>In application, PLL_FACTOR_N shall be more than or equal to 11. |
| 7:6            | R/W        | 0x0         | PLL_UNLOCK_MDSEL                                                                                                                                       |

| Offset: 0x000C |            |             | Register Name: PLL_AUDIO1_CTRL_REG                                                                          |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                 |
|                |            |             | PLL Unlock Level<br>00: 21-29 Clock Cycles<br>01: 22-28 Clock Cycles<br>1X: 20-30 Clock Cycles              |
| 5              | R/W        | 0x0         | PLL_LOCK_MDSEL<br>PLL Lock Level<br>0: 24-26 Clock Cycles<br>1: 23-27 Clock Cycles                          |
| 4:2            | /          | /           | /                                                                                                           |
| 1              | R/W        | 0x0         | PLL_INPUT_DIV2<br>PLL Input Div M<br>$M = \text{PLL\_INPUT\_DIV\_M} + 1$<br>PLL_INPUT_DIV_M is from 0 to 1. |
| 0              | /          | /           | /                                                                                                           |

#### 2.11.6.4 0x0010 PLL\_AUDIO1 Pattern0 Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0010 |            |             | Register Name: PLL_AUDIO1_PAT0_CTRL_REG                                                                               |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                           |
| 31             | R/W        | 0x0         | SIG_DELT_PAT_EN<br>Sigma Delta Pattern Enable                                                                         |
| 30:29          | R/W        | 0x0         | SPR_FREQ_MODE<br>Spread Frequency Mode<br>00: DC=0<br>01: DC=1<br>10: Triangular(1bit)<br>11: Triangular(nbit)        |
| 28:20          | R/W        | 0x0         | WAVE_STEP<br>Wave Step                                                                                                |
| 19             | R/W        | 0x0         | SDM_CLK_SEL<br>SDM Clock Selection<br>0: 24MHz<br>1: 12MHz<br>When PLL_INPUT_DIV_M1=1, this bit needs to be set to 1. |
| 18:17          | R/W        | 0x0         | FREQ<br>Frequency<br>00: 31.5 kHz<br>01: 32 kHz<br>10: 32.5 kHz<br>11: 33 kHz                                         |

| Offset: 0x0010 |            |             | Register Name: PLL_AUDIO1_PAT0_CTRL_REG |
|----------------|------------|-------------|-----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                             |
| 16:0           | R/W        | 0x0         | WAVE_BOT<br>Wave Bottom                 |

#### 2.11.6.5 0x0014 PLL\_AUDIO1 Pattern1 Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0014 |            |             | Register Name: PLL_AUDIO1_PAT1_CTRL_REG |
|----------------|------------|-------------|-----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                             |
| 31:25          | /          | /           | /                                       |
| 24             | R/W        | 0x0         | DITHER_EN<br>Dither Enable              |
| 23:21          | /          | /           | /                                       |
| 20             | R/W        | 0x0         | FRAC_EN<br>Fraction Enable              |
| 19:17          | /          | /           | /                                       |
| 16:0           | R/W        | 0x0         | FRAC_IN<br>Fraction In                  |

#### 2.11.6.6 0x0018 PLL\_AUDIO1 Bias Register (Default Value: 0x0003\_0000)

| Offset: 0x0018 |            |             | Register Name: PLL_AUDIO1_BIAS_REG |
|----------------|------------|-------------|------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                        |
| 31:21          | /          | /           | /                                  |
| 20:16          | R/W        | 0x3         | PLL_CP<br>PLL Bias Control         |
| 15:0           | /          | /           | /                                  |

#### 2.11.6.7 0x001C Audio Out Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x001C |            |             | Register Name: AUD_CLK_REG                                                                           |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                          |
| 31             | R/W        | 0x0         | AUD_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>AUD_CLK = PLL_AUDIO1 (DIV2)/M |
| 30:5           | /          | /           | /                                                                                                    |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M= FACTOR_M +1                                                               |

| Offset: 0x001C |            |             | Register Name: AUD_CLK_REG |
|----------------|------------|-------------|----------------------------|
| Bit            | Read/Write | Default/Hex | Description                |
|                |            |             | FACTOR_M is from 0 to 31   |

#### 2.11.6.8 0x002C I2S0 Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x002C |            |             | Register Name: I2S0_CLK_REG                                                                                                                                                     |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                     |
| 31             | R/W        | 0x0         | I2S0_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>I2S0_CLK = Clock Source/M/N                                                                             |
| 30:27          | /          | /           | /                                                                                                                                                                               |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Selection<br>000: AUDIO0PLL4X<br>001: AUDIO1PLL_DIV2 (low power CLK from<br>MCU_PRCM AUDIO_SYS)<br>010: AUDIO1PLL_DIV5 (from MCU_PRCM<br>AUDIO_SYS) |
| 23:10          | /          | /           | /                                                                                                                                                                               |
| 9:5            | R/W        | 0x0         | FACTOR_N<br>Factor N<br>N=FACTOR_N +1<br>FACTOR_N is from 0 to 31                                                                                                               |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M=FACTOR_M +1<br>FACTOR_M is from 0 to 31                                                                                                               |

#### 2.11.6.9 0x0030 I2S1 Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0030 |            |             | Register Name: I2S1_CLK_REG                                                                         |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                         |
| 31             | R/W        | 0x0         | I2S1_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>I2S1_CLK = Clock Source/M/N |
| 30:27          | /          | /           | /                                                                                                   |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL                                                                                         |

| Offset: 0x0030 |            |             | Register Name: I2S1_CLK_REG                                                                                                                                |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                |
|                |            |             | Clock Source Selection<br>000: AUDIO0PLL4X<br>001: AUDIO1PLL_DIV2 (low power CLK from MCU_PRCM AUDIO_SYS)<br>010: AUDIO1PLL_DIV5 (from MCU_PRCM AUDIO_SYS) |
| 23:10          | /          | /           | /                                                                                                                                                          |
| 9:5            | R/W        | 0x0         | FACTOR_N<br>Factor N<br>N=FACTOR_N +1<br>FACTOR_N is from 0 to 31.                                                                                         |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M=FACTOR_M +1<br>FACTOR_M is from 0 to 31.                                                                                         |

#### 2.11.6.10 0x0034 I2S2 Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0034 |            |             | Register Name: I2S2_CLK_REG                                                                                                                                               |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                               |
| 31             | R/W        | 0x0         | I2S2_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>I2S2_CLK = Clock Source/M/N                                                                       |
| 30:27          | /          | /           | /                                                                                                                                                                         |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Selection<br>000: AUDIO0PLL4X<br>001: AUDIO1PLL_DIV2 (low power CLK from MCU_PRCM AUDIO_SYS)<br>010: AUDIO1PLL_DIV5 (from MCU_PRCM AUDIO_SYS) |
| 23:10          | /          | /           | /                                                                                                                                                                         |
| 9:5            | R/W        | 0x0         | FACTOR_N<br>Factor N<br>N=FACTOR_N +1<br>FACTOR_N is from 0 to 31                                                                                                         |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M=FACTOR_M +1                                                                                                                                     |

| Offset: 0x0034 |            |             | Register Name: I2S2_CLK_REG |
|----------------|------------|-------------|-----------------------------|
| Bit            | Read/Write | Default/Hex | Description                 |
|                |            |             | FACTOR_M is from 0 to 31    |

#### 2.11.6.11 0x0038 I2S3 Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0038 |            |             | Register Name: I2S3_CLK_REG                                                                                                                                                     |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                     |
| 31             | R/W        | 0x0         | I2S3_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>I2S3_CLK = Clock Source/M/N                                                                             |
| 30:27          | /          | /           | /                                                                                                                                                                               |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Selection<br>000: AUDIO0PLL4X<br>001: AUDIO1PLL_DIV2 (low power CLK from<br>MCU_PRCM AUDIO_SYS)<br>010: AUDIO1PLL_DIV5 (from MCU_PRCM<br>AUDIO_SYS) |
| 23:10          | /          | /           | /                                                                                                                                                                               |
| 9:5            | R/W        | 0x0         | FACTOR_N<br>Factor N<br>N=FACTOR_N +1<br>FACTOR_N is from 0 to 31                                                                                                               |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M=FACTOR_M +1<br>FACTOR_M is from 0 to 31                                                                                                               |

#### 2.11.6.12 0x003C I2S3\_ASRC Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x003C |            |             | Register Name: I2S3_ASRC_CLK_REG                                                                              |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                   |
| 31             | R/W        | 0x0         | I2S3_ASRC_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>I2S3_ASRC_CLK = Clock Source/M/N |
| 30:27          | /          | /           | /                                                                                                             |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL                                                                                                   |

| Offset: 0x003C |            |             | Register Name: I2S3_ASRC_CLK_REG                                                                                                                          |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                               |
|                |            |             | Clock Source Selection<br>000: PERIO_300M<br>001: AUDIO1PLL_DIV2 (low power CLK from MCU_PRCM AUDIO_SYS)<br>010: AUDIO1PLL_DIV5 (from MCU_PRCM AUDIO_SYS) |
| 23:10          | /          | /           | /                                                                                                                                                         |
| 9:5            | R/W        | 0x0         | FACTOR_N<br>Factor N<br>N=FACTOR_N +1<br>FACTOR_N is from 0 to 31                                                                                         |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M=FACTOR_M +1<br>FACTOR_M is from 0 to 31                                                                                         |

#### 2.11.6.13 0x0040 I2S Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x0040 |            |             | Register Name: I2S_BGR_REG                          |
|----------------|------------|-------------|-----------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                         |
| 31:19          | /          | /           | /                                                   |
| 19             | R/W        | 0x0         | I2S3_RST<br>I2S3 Reset<br>0: Assert<br>1: De-assert |
| 18             | R/W        | 0x0         | I2S2_RST<br>I2S2 Reset<br>0: Assert<br>1: De-assert |
| 17             | R/W        | 0x0         | I2S1_RST<br>I2S1 Reset<br>0: Assert<br>1: De-assert |
| 16             | R/W        | 0x0         | I2S0_RST<br>I2S0 Reset<br>0: Assert<br>1: De-assert |
| 15:4           | /          | /           | /                                                   |
| 3              | R/W        | 0x0         | I2S3_GATING<br>Gating Clock for I2S3<br>0: Mask     |

| Offset: 0x0040 |            |             | Register Name: I2S_BGR_REG                                 |
|----------------|------------|-------------|------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                |
|                |            |             | 1: Pass                                                    |
| 2              | R/W        | 0x0         | I2S2_GATING<br>Gating Clock for I2S2<br>0: Mask<br>1: Pass |
| 1              | R/W        | 0x0         | I2S1_GATING<br>Gating Clock for I2S1<br>0: Mask<br>1: Pass |
| 0              | R/W        | 0x0         | I2S0_GATING<br>Gating Clock for I2S0<br>0: Mask<br>1: Pass |

#### 2.11.6.14 0x0044 OWA\_TX Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0044 |            |             | Register Name: OWA_TX_CLK_REG                                                                                                                                                   |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                     |
| 31             | R/W        | 0x0         | OWA_TX_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>OWA_TX_CLK = Clock Source/M/N                                                                         |
| 30:27          | /          | /           | /                                                                                                                                                                               |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Selection<br>000: AUDIO0PLL4X<br>001: AUDIO1PLL_DIV2 (low power CLK from<br>MCU_PRCM AUDIO_SYS)<br>010: AUDIO1PLL_DIV5 (from MCU_PRCM<br>AUDIO_SYS) |
| 23:10          | /          | /           | /                                                                                                                                                                               |
| 9:5            | R/W        | 0x0         | FACTOR_N<br>N=FACTOR_N +1                                                                                                                                                       |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M=FACTOR_M +1<br>FACTOR_M is from 0 to 31                                                                                                               |

#### 2.11.6.15 0x0048 OWA\_RX Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0048 |            |             | Register Name: OWA_RX_CLK_REG                                                                                                                                                 |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                   |
| 31             | R/W        | 0x0         | OWA_RX_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>OWA_RX_CLK = Clock Source/M/N                                                                       |
| 30:27          | /          | /           | /                                                                                                                                                                             |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Selection<br>000: PERIO_300M<br>001: AUDIO1PLL_DIV2(low power CLK from<br>MCU_PRCM AUDIO_SYS)<br>010: AUDIO1PLL_DIV5 (from MCU_PRCM<br>AUDIO_SYS) |
| 23:10          | /          | /           | /                                                                                                                                                                             |
| 9:5            | R/W        | 0x0         | FACTOR_N<br>Factor N<br>N=FACTOR_N +1<br>FACTOR_N is from 0 to 31                                                                                                             |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M=FACTOR_M +1<br>FACTOR_M is from 0 to 31                                                                                                             |

#### 2.11.6.16 0x004C OWA Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x004C |            |             | Register Name: OWA_BGR_REG                               |
|----------------|------------|-------------|----------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                              |
| 31:17          | /          | /           | /                                                        |
| 16             | R/W        | 0x0         | OWA_RST<br>OWA Reset<br>0: Assert<br>1: De-assert        |
| 15:1           | /          | /           | /                                                        |
| 0              | R/W        | 0x0         | OWA_GATING<br>Gating Clock for OWA<br>0: Mask<br>1: Pass |

## 2.11.6.17 0x0050 DMIC Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0050 |            |             | Register Name: DMIC_CLK_REG                                                                                                                                                     |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                     |
| 31             | R/W        | 0x0         | DMIC_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>DMIC_CLK = Clock Source/M/N                                                                             |
| 30:27          | /          | /           | /                                                                                                                                                                               |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Selection<br>000: AUDIO0PLL4X<br>001: AUDIO1PLL_DIV2 (low power CLK from<br>MCU_PRCM AUDIO_SYS)<br>010: AUDIO1PLL_DIV5 (from MCU_PRCM<br>AUDIO_SYS) |
| 23:10          | /          | /           | /                                                                                                                                                                               |
| 9:5            | R/W        | 0x0         | FACTOR_N<br>Factor N<br>N=FACTOR_M +1<br>FACTOR_N is from 0 to 31                                                                                                               |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M=FACTOR_M +1<br>FACTOR_M is from 0 to 31                                                                                                               |

## 2.11.6.18 0x0054 DMIC Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x0054 |            |             | Register Name: DMIC_BGR_REG                                |
|----------------|------------|-------------|------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                |
| 31:17          | /          | /           | /                                                          |
| 16             | R/W        | 0x0         | DMIC_RST<br>DMIC Reset<br>0: Assert<br>1: De-assert        |
| 15:1           | /          | /           | /                                                          |
| 0              | R/W        | 0x0         | DMIC_GATING<br>Gating Clock for DMIC<br>0: Mask<br>1: Pass |

## 2.11.6.19 0x0058 AUDIO\_CODEC\_DAC Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0058 |            |             | Register Name: AUDIO_CODEC_DAC_CLK_REG                                                                                                                                          |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                     |
| 31             | R/W        | 0x0         | AUDIO_CODEC_DAC_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>AUDIO_CODEC_DAC_CLK = Clock Source/M/N                                                       |
| 30:27          | /          | /           | /                                                                                                                                                                               |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Selection<br>000: AUDIO0PLL4X<br>001: AUDIO1PLL_DIV2 (low power CLK from<br>MCU_PRCM AUDIO_SYS)<br>010: AUDIO1PLL_DIV5 (from MCU_PRCM<br>AUDIO_SYS) |
| 23:10          | /          | /           | /                                                                                                                                                                               |
| 9:5            | R/W        | 0x0         | FACTOR_N<br>Factor N<br>N=FACTOR_N +1<br>FACTOR_N is from 0 to 31                                                                                                               |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M=FACTOR_M +1<br>FACTOR_M is from 0 to 31                                                                                                               |

## 2.11.6.20 0x005C AUDIO\_CODEC\_ADC Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x005C |            |             | Register Name: AUDIO_CODEC_ADC_CLK_REG                                                                                      |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                 |
| 31             | R/W        | 0x0         | AUDIO_CODEC_ADC_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>AUDIO_CODEC_ADC_CLK = Clock Source/M/N   |
| 30:27          | /          | /           | /                                                                                                                           |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Selection<br>000: AUDIO0PLL4X<br>001: AUDIO1PLL_DIV2 (low power CLK from<br>MCU_PRCM AUDIO_SYS) |

| Offset: 0x005C |            |             | Register Name: AUDIO_CODEC_ADC_CLK_REG                            |
|----------------|------------|-------------|-------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                       |
|                |            |             | 010: AUDIO1PLL_DIV5 (from MCU_PRCM<br>AUDIO_SYS)                  |
| 23:10          | /          | /           | /                                                                 |
| 9:5            | R/W        | 0x0         | FACTOR_N<br>Factor N<br>N=FACTOR_N +1<br>FACTOR_N is from 0 to 31 |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M=FACTOR_M +1<br>FACTOR_M is from 0 to 31 |

#### 2.11.6.21 0x0060 AUDIO\_CODEC Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x0060 |            |             | Register Name: AUDIO_CODEC_BGR_REG                                       |
|----------------|------------|-------------|--------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                              |
| 31:17          | /          | /           | /                                                                        |
| 16             | R/W        | 0x0         | AUDIO_CODEC_RST<br>AUDIO_CODEC Reset<br>0: Assert<br>1: De-assert        |
| 15:1           | /          | /           | /                                                                        |
| 0              | R/W        | 0x0         | AUDIO_CODEC_GATING<br>Gating Clock for AUDIO_CODEC<br>0: Mask<br>1: Pass |

#### 2.11.6.22 0x0064 AHBS Ready Timeout Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0064 |       |             | Register Name: AHBS_RDY_TOUT_CTRL_REG                                                         |
|----------------|-------|-------------|-----------------------------------------------------------------------------------------------|
| Bit            | R/W   | Default/Hex | Description                                                                                   |
| 31:25          | /     | /           | /                                                                                             |
| 24             | R/W1C | 0x0         | AHBS_RDY_TIMEOUT_IRQ_PEND<br>AHBS Hready Time Out IRQ Pending<br>Write 1 Clear                |
| 23:9           | /     | /           | /                                                                                             |
| 8              | R/W   | 0x0         | AHBS_RDY_TIMEOUT_IRQ_EN<br>AHBS Hready Time Out IRQ Enable<br>1: IRQ Enable<br>0: IRQ Disable |

| Offset: 0x0064 |     |             | Register Name: AHBS_RDY_TOUT_CTRL_REG                                                                                                      |
|----------------|-----|-------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                                                                                                                |
| 7              | R/W | 0x0         | AHBS_TIMEOUT_INT_VAL_SEL<br>AHBS Time Out Interval Value Selection<br>0: interal_value* 2^10 + 2^10 -1<br>1: interal_value* 2^16 + 2^16 -1 |
| 6:1            | R/W | 0x0         | AHBS_TIMEOUT_CNT_INT_VAL<br>AHBS Time Out Counter Interval Value                                                                           |
| 0              | R/W | 0x0         | AHBS_RDY_TIMEOUT_EN<br>AHBS Hready Time Out Enable                                                                                         |

#### 2.11.6.23 0x0074 MCU\_TIMER0 Clock Register (Default: 0x0000\_0000)



##### NOTE

In low power mode, MCU\_TIMER uses AHB\_HCLK\_MUX clock which is generated by the PLL in MCU\_PRCM.

| Offset: 0x0074 |     |             | Register Name: TIMER0_CLK_REG                                                                                                                                                                         |
|----------------|-----|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                                                                                                                                                                           |
| 31:6           | /   | /           | /                                                                                                                                                                                                     |
| 5:4            | R/W | 0x0         | CLK_SRC_SEL<br>MCU_TIMER0 Clock Source Selection<br>00: CLK24M<br>01: CLK32K<br>10:CLK_RC<br>11: AHB_HCLK_MUX(200MHz)<br>MCU_TIMER0 clock input, the clock sources are 24 MHz/RC 16M/CLK32K/ 200 MHz. |
| 3:1            | R/W | 0x0         | MCU_TIMER0_CLK_DIVN<br>Select the pre-scale of MCU_TIMER0 clock source<br>000: /1<br>001: /2<br>010: /4<br>011: /8<br>100: /16<br>101: /32<br>110: /64<br>111: /128                                   |
| 0              | R/W | 0x0         | MCU_TIMER0_CLK_GATING<br>0: Disable<br>1: Enable                                                                                                                                                      |

### 2.11.6.24 0x0078 MCU\_TIMER1 Clock Register (Default: 0x0000\_0000)



In low power mode, MCU\_TIMER uses AHB\_HCLK\_MUX clock which is generated by the PLL in MCU\_PRCM.

| Offset: 0x0078 |     |             | Register Name: MCU_TIMER1_CLK_REG                                                                                                                                                                               |
|----------------|-----|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                                                                                                                                                                                     |
| 31:6           | /   | /           | /                                                                                                                                                                                                               |
| 5:4            | R/W | 0x0         | CLK_SRC_SEL<br>MCU_TIMER1 clock source selection<br>00: CLK24M<br>01: CLK32K<br>10:CLK_RC<br>11: AHB_HCLK_MUX(200MHz/24.576x4M)<br>MCU_TIMER1 clock input, the clock sources are 24 MHz/RC 16M/CLK32K/ 200 MHz. |
| 3:1            | R/W | 0x0         | MCU_TIMER1_CLK_DIVN<br>Select the pre-scale of MCU_TIMER1 clock source<br>000: /1<br>001: /2<br>010: /4<br>011: /8<br>100: /16<br>101: /32<br>110: /64<br>111: /128                                             |
| 0              | R/W | 0x0         | MCU_TIMER1_CLK_GATING<br>0: Disable<br>1: Enable                                                                                                                                                                |

### 2.11.6.25 0x007C MCU\_TIMER2 Clock Register (Default: 0x0000\_0000)



In low power mode, MCU\_TIMER uses AHB\_HCLK\_MUX clock which is generated by the PLL in MCU\_PRCM.

| Offset: 0x007C |     |             | Register Name: MCU_TIMER2_CLK_REG |
|----------------|-----|-------------|-----------------------------------|
| Bit            | R/W | Default/Hex | Description                       |

| Offset: 0x007C |     |             | Register Name: MCU_TIMER2_CLK_REG                                                                                                                                                                               |
|----------------|-----|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                                                                                                                                                                                     |
| 31:6           | /   | /           | /                                                                                                                                                                                                               |
| 5:4            | R/W | 0x0         | CLK_SRC_SEL<br>MCU_TIMER2 clock source selection<br>00: CLK24M<br>01: CLK32K<br>10:CLK_RC<br>11: AHB_HCLK_MUX(200MHz/24.576x4M)<br>MCU_TIMER2 clock input, the clock sources are 24 MHz/RC 16M/CLK32K/ 200 MHz. |
| 3:1            | R/W | 0x0         | MCU_TIMER2_CLK_DIVN<br>Select the pre-scale of MCU_TIMER2 clock source.<br>000: /1<br>001: /2<br>010: /4<br>011: /8<br>100: /16<br>101: /32<br>110: /64<br>111: /128                                            |
| 0              | R/W | 0x0         | MCU_TIMER2_CLK_GATING<br>0: Disable<br>1: Enable                                                                                                                                                                |

#### 2.11.6.26 0x0080 MCU\_TIMER3 Clock Register (Default: 0x0000\_0000)



In low power mode, MCU\_TIMER uses AHB\_HCLK\_MUX clock which is generated by the PLL in MCU\_PRCM.

| Offset: 0x0080 |     |             | Register Name: MCU_TIMER3_CLK_REG                                                                                                                                                   |
|----------------|-----|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                                                                                                                                                         |
| 31:6           | /   | /           | /                                                                                                                                                                                   |
| 5:4            | R/W | 0x0         | CLK_SRC_SEL<br>MCU_TIMER3 Clock Source selection<br>00: CLK24M<br>01: CLK32K<br>10:CLK_RC<br>11: AHB_HCLK_MUX(200MHz/24.576x4M)<br>MCU_TIMER3 clock input, the clock sources are 24 |

| Offset: 0x0080 |     |             | Register Name: MCU_TIMER3_CLK_REG                                                                                                                                                          |
|----------------|-----|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                                                                                                                                                                |
|                |     |             | MHz/RC 16M/CLK32K/ 200 MHz.                                                                                                                                                                |
| 3:1            | R/W | 0x0         | <p>MCU_TIMER3_CLK_DIVN</p> <p>Select the pre-scale of MCU_TIMER2 clock source.</p> <p>000: /1<br/>001: /2<br/>010: /4<br/>011: /8<br/>100: /16<br/>101: /32<br/>110: /64<br/>111: /128</p> |
| 0              | R/W | 0x0         | <p>MCU_TIMER3_CLK_GATING</p> <p>0: Disable<br/>1: Enable</p>                                                                                                                               |

#### 2.11.6.27 0x0084 MCU\_TIMER4 Clock Register (Default: 0x0000\_0000)

| Offset: 0x0084 |     |             | Register Name: MCU_TIMER4_CLK_REG                                                                                                                                                                                                     |
|----------------|-----|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                                                                                                                                                                                                           |
| 31:6           | /   | /           | /                                                                                                                                                                                                                                     |
| 5:4            | R/W | 0x0         | <p>CLK_SRC_SEL</p> <p>MCU_TIMER4 clock source selection</p> <p>00: CLK24M<br/>01: CLK32K<br/>10:CLK_RC<br/>11: AHB_HCLK_MUX(200MHz/24.576x4M)</p> <p>MCU_TIMER4 clock input, the clock sources are 24 MHz/RC 16M/CLK32K/ 200 MHz.</p> |
| 3:1            | R/W | 0x0         | <p>MCU_TIMER4_CLK_DIVN</p> <p>Select the pre-scale of MCU_TIMER4 clock source</p> <p>000: /1<br/>001: /2<br/>010: /4<br/>011: /8<br/>100: /16<br/>101: /32<br/>110: /64<br/>111: /128</p>                                             |
| 0              | R/W | 0x0         | <p>MCU_TIMER4_CLK_GATING</p> <p>0: Disable<br/>1: Enable</p>                                                                                                                                                                          |

#### 2.11.6.28 0x0088 MCU\_TIMER5 Clock Register (Default: 0x0000\_0000)

| Offset: 0x0088 |     |             | Register Name: MCU_TIMER5_CLK_REG                                                                                                                                                                                            |
|----------------|-----|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                                                                                                                                                                                                  |
| 31:6           | /   | /           | /                                                                                                                                                                                                                            |
| 5:4            | R/W | 0x0         | <p>CLK_SRC_SEL<br/>MCU_TIMER5 Clock Source Selection<br/>00: CLK24M<br/>01: CLK32K<br/>10:CLK_RC<br/>11: AHB_HCLK_MUX(200MHz/24.576x4M)<br/>MCU_TIMER5 clock input, the clock sources are 24 MHz/RC 16M/CLK32K/ 200 MHz.</p> |
| 3:1            | R/W | 0x0         | <p>MCU_TIMER5_CLK_DIVN<br/>Select the pre-scale of MCU_TIMER5 clock source.<br/>000: /1<br/>001: /2<br/>010: /4<br/>011: /8<br/>100: /16<br/>101: /32<br/>110: /64<br/>111: /128</p>                                         |
| 0              | R/W | 0x0         | <p>MCU_TIMER5_CLK_GATING<br/>0: Disable<br/>1: Enable</p>                                                                                                                                                                    |

#### 2.11.6.29 0x008C MCU\_TIMER Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x008C |            |             | Register Name: MCU_TIMER_BGR_REG                                                       |
|----------------|------------|-------------|----------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                            |
| 31:17          | /          | /           | /                                                                                      |
| 16             | R/W        | 0x0         | <p>MCU_TIMER_RST<br/>MCU_TIMER Reset<br/>0: Assert<br/>1: De-assert</p>                |
| 15:1           | /          | /           | /                                                                                      |
| 0              | R/W        | 0x0         | <p>MCU_TIMER_GATING<br/>Gating Clock for MCU_TIMER AHB_CLK<br/>0: Mask<br/>1: Pass</p> |

#### 2.11.6.30 0x0104 MCU\_DMAC Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x0104 |            |             | Register Name: MCU_DMA_BGR_REG                                            |
|----------------|------------|-------------|---------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                               |
| 31:17          | /          | /           | /                                                                         |
| 16             | R/W        | 0x0         | <b>MCU_DMAC_RST</b><br>MCU DMAC Reset<br>0: Assert<br>1: De-assert        |
| 15:1           | /          | /           | /                                                                         |
| 0              | R/W        | 0x0         | <b>MCU_DMAC_GATING</b><br>Gating Clock for MCU_DMAC<br>0: Mask<br>1: Pass |

#### 2.11.6.31 0x0114 PUBSRAM Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x0114 |            |             | Register Name: PUBSRAM_BGR_REG                                          |
|----------------|------------|-------------|-------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                             |
| 31:17          | /          | /           | /                                                                       |
| 16             | R/W        | 0x0         | <b>PUBSRAM_RST</b><br>PUBSRAM Reset<br>0: Assert<br>1: De-assert        |
| 15:1           | /          | /           | /                                                                       |
| 0              | R/W        | 0x0         | <b>PUBSRAM_GATING</b><br>Gating Clock for PUBSRAM<br>0: Mask<br>1: Pass |

#### 2.11.6.32 0x0118 AHBS1 Ready Timeout Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0118 |       |             | Register Name: AHBS1_RDY_TOUT_CTRL_REG                                                 |
|----------------|-------|-------------|----------------------------------------------------------------------------------------|
| Bit            | R/W   | Default/Hex | Description                                                                            |
| 31:25          | /     | /           | /                                                                                      |
| 24             | R/W1C | 0x0         | <b>AHBS1_RDY_TIMEOUT_IRQ_PEND</b><br>AHBS Hready Time Out IRQ Pending<br>Write 1 Clear |
| 23:9           | /     | /           | /                                                                                      |
| 8              | R/W   | 0x0         | <b>AHBS1_RDY_TIMEOUT_IRQ_EN</b><br>AHBS Hready Time Out IRQ Enable<br>1: IRQ Enable    |

| Offset: 0x0118 |     |             | Register Name: AHBS1_RDY_TOUT_CTRL_REG                                                                                                      |
|----------------|-----|-------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | R/W | Default/Hex | Description                                                                                                                                 |
|                |     |             | 0: IRQ Disable                                                                                                                              |
| 7              | R/W | 0x0         | AHBS1_TIMEOUT_INT_VAL_SEL<br>AHBS Time Out Interval Value Selection<br>0: interal_value* 2^10 + 2^10 -1<br>1: interal_value* 2^16 + 2^16 -1 |
| 6:1            | R/W | 0x0         | AHBS1_TIMEOUT_CNT_INT_VAL<br>AHBS Time Out Counter Interval Value                                                                           |
| 0              | R/W | 0x0         | AHBS1_RDY_TIMEOUT_EN<br>AHBS Hready Time Out Enable                                                                                         |

#### 2.11.6.33 0x011C MCLK Gating Configuration Register (Default Value: 0x0000\_0000)

| Offset: 0x011C |            |             | Register Name: MCLK_GATING_CFG_REG                                   |
|----------------|------------|-------------|----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                          |
| 31:2           | /          | /           | /                                                                    |
| 1              | R/W        | 0x0         | MCUSYS_MCLK_EN<br>Gating Clock for MCUSYS_MCLK<br>0: Mask<br>1: Pass |
| 0              | R/W        | 0x0         | DMA_MCLK_EN<br>Gating Clock for DMA_MCLK<br>0: Mask<br>1: Pass       |

#### 2.11.6.34 0x0120 RISCV Clock Register (Default Value: 0x0000\_0020)

| Offset: 0x0120 |            |             | Register Name: RISCV_CLK_REG                                                                                                     |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                      |
| 31             | R/W        | 0x0         | RISCV_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>RISCV_CLK = Clock Source/M/N                            |
| 30             | /          | /           | /                                                                                                                                |
| 29:27          | R/W        | 0x0         | RSICVCLK_24M_SRC_SEL<br>Clock Source Selection<br>000: CLK24M (from CCU)<br>001: CLK32K (from CCU)<br>010: CLK_RC (from CCU 16M) |
| 26:0           | /          | /           | /                                                                                                                                |

### 2.11.6.35 0x0124 RISCV CFG Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x0124 |            |             | Register Name: RISCV_CFG_BGR_REG                                       |
|----------------|------------|-------------|------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                            |
| 31:19          | /          | /           | /                                                                      |
| 18             | R/W        | 0x0         | RISCV_CORE_RST<br>RISCV CORE Reset<br>0: Assert<br>1: De-assert        |
| 17             | R/W        | 0x0         | RISCV_APB_DB_RST<br>RISCV APB Debug Reset<br>0: Assert<br>1: De-assert |
| 16             | R/W        | 0x0         | RISCV_CFG_RST<br>RISCV CFG Reset<br>0: Assert<br>1: De-assert          |
| 15:1           | /          | /           | /                                                                      |
| 0              | R/W        | 0x0         | RISCV_CFG_GATING<br>Gating Clock for RISCV_CFG<br>0: Mask<br>1: Pass   |

### 2.11.6.36 0x0128 RISCV\_MSGBOX Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x0128 |            |             | Register Name: RISCV_MSGBOX_BGR_REG                                        |
|----------------|------------|-------------|----------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                |
| 31:17          | /          | /           | /                                                                          |
| 16             | R/W        | 0x0         | RISCV_MSGBOX_RST<br>RISCV_MSGBOX Reset<br>0: Assert<br>1: De-assert        |
| 15:1           | /          | /           | /                                                                          |
| 0              | R/W        | 0x0         | RISCV_MSGBOX_GATING<br>Gating Clock for RISCV_MSGBOX<br>0: Mask<br>1: Pass |

### 2.11.6.37 0x0130 MCU\_PWMCTRL Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0130 |            |             | Register Name: MCU_PWMCTRL_CLK_REG |
|----------------|------------|-------------|------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                        |

| Offset: 0x0130 |            |             | Register Name: MCU_PWMCTRL_CLK_REG                                                        |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                               |
| 31             | R/W        | 0x0         | PWMCTRL_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON                   |
| 30             | /          | /           | /                                                                                         |
| 26:24          | R/W        | 0x0         | PWMCTRL_CLK_SRC_SEL<br>Clock Source Selection<br>000: CLK24M<br>001: CLK32K<br>010:CLK_RC |
| 23:0           | /          | /           | /                                                                                         |

#### 2.11.6.38 0x0134 MCU\_PWMCTRL Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x0134 |            |             | Register Name: MCU_PWMCTRL_BGR_REG                                            |
|----------------|------------|-------------|-------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                   |
| 31:17          | /          | /           | /                                                                             |
| 16             | R/W        | 0x0         | MCU_PWMCTRL_RST<br>MCU_PWMCTRL Reset<br>0: Assert<br>1: De-assert             |
| 15:1           | /          | /           | /                                                                             |
| 0              | R/W        | 0x0         | MCU_PWMCTRL_GATING<br>Gating Clock for MCU_PWMCTRL PCLK<br>0: Mask<br>1: Pass |

#### 2.11.6.39 0x0160 PLL Backdoor Output Enable Register (Default Value: 0x0000\_0000)

| Offset: 0x0160 |            |             | Register Name: PLL_BACKDOOR_OUTPUT_EN_REG                         |
|----------------|------------|-------------|-------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                       |
| 31:1           | /          | /           | /                                                                 |
| 0              | R/W        | 0x0         | PLL_AUDIO1_ENABLE<br>PLL AUDIO1 Enable<br>0: Disable<br>1: Enable |

## 2.11.6.40 0x0164 Test Debug Register (Default Value: 0x0000\_0000)

| Offset: 0x0164 |            |             | Register Name: TEST_DBG_REG                                                                                                                           |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                           |
| 31             | R/W        | 0x0         | PLL_OUT_TEST_EN<br>PLL Clock Output to PLLTEST pin Enable<br>PLLTEST = PLL CLK Source/PLL_TEST_P_DIV<br>0: disable,<br>1: PLL Clock Output to PLLTEST |
| 30:25          | /          | /           | /                                                                                                                                                     |
| 24             | R/W        | 0x0         | PLL_CLK_SOURCE<br>AUDIOPLL Clock output selection on<br>0: AudioPLL output clock<br>1: AudioPLL reference clock                                       |
| 23:22          | /          | /           | /                                                                                                                                                     |
| 21:20          | R/W        | 0x0         | PLL_TEST_P_DIV<br>PLL TEST Post Divider<br>00: /1<br>01: /2<br>10: /4<br>11: /8                                                                       |
| 19:0           | /          | /           | /                                                                                                                                                     |

## 2.12 RTC

### 2.12.1 Overview

The Real Time Clock (RTC) is used to implement the time counter and the timing wakeup functions. The RTC can display the year, month, day, week, hour, minute, second in real time. The RTC has the independent power to continue to work in system power-off.

The RTC has the following features:

- Provides a 16-bit counter for counting day, 5-bit counter for counting hour, 6-bit counter for counting minute, 6-bit counter for counting second
- Timer frequency is 1 kHz
- Configurable initial value by software anytime
- Supports timing alarm, and generates interrupt and wakeup the external devices
- Supports fanout function of internal 32K clock
- 8 general purpose registers for storing the power-off information
- Multiple special registers for recording the BROM information



#### NOTE

The register configuration of RTC is AHB bus, it only can support word operation, not byte operation and half-word operation.

## 2.12.2 Block Diagram

The following figure shows the block diagram of the RTC.

**Figure 2-29 RTC Block Diagram**



## 2.12.3 Functional Descriptions

### 2.12.3.1 External Signals

**Table 2-19 RTC External Signals**

| Signal Name | Description                                                                  | Type  |
|-------------|------------------------------------------------------------------------------|-------|
| X32KFOUT    | 32.768 kHz clock Fanout<br>Provides low frequency clock for external devices | AO,OD |
| X32KIN      | Clock Input of 32.768 kHz Crystal                                            | AI    |
| X32KOUT     | Clock Output of 32.768 kHz Crystal                                           | AO    |
| DXIN        | Digital Compensated Crystal Oscillator Input                                 | AI    |
| DXOUT       | Digital Compensated Crystal Oscillator Output                                | AO    |

| Signal Name | Description                                         | Type    |
|-------------|-----------------------------------------------------|---------|
| REFCLK-OUT  | Digital Compensated Crystal Oscillator Clock Fanout | AO      |
| WREQIN      | Request signal of REFCLK_OUT                        | AI      |
| NMI         | Non-Maskable Interrupt                              | I/O, OD |
| RESET       | Reset Signal (Low Active)                           | I/O, OD |
| VCC-DCXO    | Digital Compensated Crystal Oscillator Power Supply | P       |
| VCC-RTC     | RTC Power                                           | P       |

### 2.12.3.2 Typical Application

Figure 2-30 RTC Application Diagram



### 2.12.3.3 Clock Tree

The following figure shows the clock tree of the RTC.

**Figure 2-31 RTC Clock Tree**



#### RTC

The RTC has three clock sources:

- 32K divided by internal 16 MHz RC
- 32K divided by external DCXO
- external 32.768 kHz crystal

The RTC selects the internal RC by default, when the system starts, the RTC can select the external low frequency crystal to provide much accurate clock by software. The clock accuracy of the RTC is related to the accuracy of the external low frequency crystal. Usually 32.768 kHz crystal with  $\pm 50$  ppm frequency tolerance is selected as the clock source. When using internal RC, the clock can be changed by changing division ratio. When using external clock, the clock cannot be changed.

#### System 32K

The system32K has three clock sources:

- 32K divided by the internal 16 MHz RC
- 32K divided by external DCXO
- external 32.768 kHz crystal

#### RTC\_32K\_FANOUT

The RTC\_32K\_FANOUT has three clock sources:

- 32K divided by the internal 16 MHz RC
- 32K divided by external DCXO
- external 32.768 kHz crystal

### 2.12.3.4 Real Time Clock

Figure 2-32 RTC Counter



The 1 kHz counter adds 1 on each rising edge of the clock. When the clock number reaches 0x3FF, 1 kHz counter starts to count again from 0, and the second counter adds 1. The step structure of 1 kHz counter is as follows.

Figure 2-33 RTC 1 kHz Counter Step Structure



According to above implementation, the changing range of each counter is as follows.

Table 2-20 RTC Counter Changing Range

| Counter | Range                                                                                      |
|---------|--------------------------------------------------------------------------------------------|
| Second  | 0 to 59                                                                                    |
| Minute  | 0 to 59                                                                                    |
| Hour    | 0 to 23                                                                                    |
| Day     | 0 to 65535 (The year, month, day need be transformed by software according to day counter) |



CAUTION

Because there is no error correction mechanism in the hardware, note that each counter configuration should not exceed a reasonable counting range.

### 2.12.3.5 Alarm 0

The principle of alarm0 is a comparator. When RTC timer reaches scheduled time, the RTC generates the interrupt, or outputs low level signal by NMI pin to wakeup power management chip.

The RTC only generates one interrupt when RTC timer reached the scheduled day, hour, minute and second counter, then the RTC need set a new scheduled time, the next interrupt can be generated.

### 2.12.3.6 RTC-VIO

The RTC module has a LDO, the input source of the LDO is VCC-RTC, the output of the LDO is RTC-VIO, the value of RTC-VIO is adjustable, the RTC\_VIO is mainly used for internal digital logic.

### 2.12.3.7 RC Calibration

**Figure 2-34 Calibration Circuit**



**Figure 2-35 RC Waveform**



The basic circuit of RC calibration is shown in Figure 2-34. Whether to output the calibrated RC clock can be selected by the RC\_Cali\_SEL control bit, the calibration principle is as follows:

- Step 1** As shown in Figure 2-35, with DCXO 24M as the reference clock, calculate the counter number M of RC clock within 1 ms/16 ms/128 ms to obtain the accurate frequency of internal RC.
- Step 2** Divide the accurate frequency by 32.768 kHz and the frequency divider(K) from RC clock to 32.768 kHz is obtained.
- Step 3** Divide RC16M by the frequency divider(K) to obtain 32.768 kHz frequency.

 NOTE

The calibration principle is to output 32.768 kHz, not to input 16 MHz.

#### 2.12.3.8 DCXO Timed Wakeup

The logic of DCXO timed wakeup circuit includes two controls: timed wakeup hardware automatic enable and timed wakeup time length (software configuration). The timed wakeup means that DCXO circuit is required to wakeup the output clock once every second (1s-60s, usually the ambient temperature changes little in a few seconds) for 32K calibration in the super standby or shutdown scenario, after calibration, DCXO circuit is closed, the closed time is timed wakeup time length (software configuration). The time of DCXO circuit from wakeup starting to stable output is 3 ms-4 ms. Although the timed wakeup function is closed, DCXO circuit always had worked. The process of timed wakeup is shown in the following figure.

Figure 2-36 DCXO Timed Wakeup Waveform



The time of a calibration in shutdown or super standby:

the timed wakeup time configured by software + the clock time of DCXO from wakeup to stable output + the time of a calibration.

The timed wakeup time configured by the software in the figure is 1 s, and can be configured by software in application. It is the theoretical maximum value for DCXO from wakeup to stable output clock in 4 ms, the specific value is subject to IC measured results. In the any time of these three periods, the startup or exit of the super standby action will not cause DCXO abnormal.

The enable signal of DCXO and the enable signal of timed wakeup DCXO is "OR" logic, and they do not contradict each other.

The interval between continuous DCXO enable operation and disable operation is at least greater than 4 ms.

### 2.12.3.9 RC Calibration Usage Scenario

Power-on: Select non-accurate 32K divided by internal RC.

Normal scenario: Select external accurate 32K, or external calibrated 32K.

Standby or power-off scenario: Select external accurate 32K, or external calibrated 32K.

### 2.12.4 Programming Guidelines

#### 2.12.4.1 RTC Clock Control

**Step 1** Select clock source: Select clock source by the bit0 of [LOSC\\_CTRL\\_REG](#), the clock source is the internal RC oscillator by default. When the system starts, the clock source can be switched to the external 32K oscillator by software.

**Step 2** Auto switch: After enabled the bit [15:14] of [LOSC\\_CTRL\\_REG](#), the RTC automatically switches clock source to the internal oscillator when the external crystal could not output waveform, the switch status can query by the bit [1] of [LOSC\\_AUTO\\_SWT\\_STA\\_REG](#).



#### NOTE

If only configuring the bit [15] of [LOSC\\_CTRL\\_REG](#), the clock source status bit cannot be changed after the auto switch is valid, because the two functions are independent.

Here are the basic code samples.

```
Write (0x16aa4000, LOSC_Ctrl); //Write key field
```

```
Write (0x16aa4001, LOSC_Ctrl); //Select the external 32K clock
```

#### 2.12.4.2 RTC Calendar

**Step 1** Write time initial value: Write the current time to [RTC\\_DAY\\_REG](#) and [RTC\\_HH\\_MM\\_SS\\_SET\\_REG](#).

**Step 2** After updated time, the RTC restarts to count again. The software can read the current time anytime.



#### NOTE

- The RTC can only provide day counter, so the current day counter need be converted to year, month, day and week by software.
- Ensure the bit [8:7] of [LOSC\\_CTRL\\_REG](#) is 0 before the next time configuration is performed.

Here are the basic code samples.

For example: set time to 21st, 07:08:09 and read it.

```
RTC_DAY_REG = 0x00000015;
```

```
RTC_HH_MM_SS_REG = 0x00070809; //0000 0000 000|0 0000(Hour) 00|00 0000(Minute) 00|00  
0000(Second)
```

```
Read (RTC_DAY_REG);
```

```
Read (RTC_HH_MM_SS_REG);
```

#### 2.12.4.3 Alarm0

**Step 1** Enable alram0 interrupt by writing [ALARM0\\_IRQ\\_EN](#).

**Step 2** Set the counter comparator, write the count-down day, hour, minute, second number to [ALARM0\\_DAY\\_SET\\_REG](#) and [ALARM0\\_CUR\\_VLU\\_REG](#).

**Step 3** Enable alarm0 function by writing [ALARM0\\_ENABLE\\_REG](#), then the software can query alarm count value in real time by [ALARM0\\_DAY\\_SET\\_REG](#) and [ALARM0\\_CUR\\_VLU\\_REG](#). When the setting time reaches, [ALARM0\\_IRQ\\_STA\\_REG](#) is set to 1 to generate interrupt.

**Step 4** After enter the interrupt process, write [ALARM0\\_IRQ\\_STA\\_REG](#) to clear the interrupt pending, and execute the interrupt process.

**Step 5** Resume the interrupt and continue to execute the interrupted process.

**Step 6** The power-off wakeup is generated via SoC hardware and PMIC, the software only needs to set the pending condition of alarm0, and set [ALARM0\\_CONFIG\\_REG](#) to 1.

#### 2.12.4.4 Fanout

##### CLK32K Fanout

Set the LOSC\_OUT\_GATING bit (bit [0]) of [CLK32K\\_FOUT\\_CTRL\\_GATING\\_REG](#) register to 1, and ensure external pull-up resistor, voltage, and clock source are normal, then 32.768kHz square wave can be output.

##### CLK24M Fanout

To fanout CLK24M clock though REFCLK-OUT pin, configure the CLK\_REQ\_ENB bit (bit [31]) of [DCXO\\_CTRL\\_REG](#) register.

#### 2.12.5 Register List

| Module Name | Base Address |
|-------------|--------------|
| RTC         | 0x0709 0000  |

| Register Name               | Offset                 | Description                                      |
|-----------------------------|------------------------|--------------------------------------------------|
| <b>VDD_RTC Power Domain</b> |                        |                                                  |
| LOSC_CTRL_REG               | 0x0000                 | LOSC Control Register                            |
| LOSC_AUTO_SWT_STA_REG       | 0x0004                 | LOSC Auto Switch Status Register                 |
| INTOSC_CLK_PRESCAL_REG      | 0x0008                 | Internal OSC Clock Prescalar Register            |
| INTOSC_CLK_AUTO_CALI_REG    | 0x000C                 | Internal OSC Clock Auto Calibration Register     |
| RTC_DAY_REG                 | 0x0010                 | RTC Year-Month-Day Register                      |
| RTC_HH_MM_SS_SET_REG        | 0x0014                 | RTC Hour-Minute-Second Register                  |
| ALARM0_DAY_SET_REG          | 0x0020                 | Alarm 0 Day Set Register                         |
| ALARM0_CUR_VLU_REG          | 0x0024                 | Alarm 0 Counter Current Value Register           |
| ALARM0_ENABLE_REG           | 0x0028                 | Alarm 0 Enable Register                          |
| ALARM0_IRQ_EN               | 0x002C                 | Alarm 0 IRQ Enable Register                      |
| ALARM0_IRQ_STA_REG          | 0x0030                 | Alarm 0 IRQ Status Register                      |
| ALARM0_CONFIG_REG           | 0x0050                 | Alarm 0 Configuration Register                   |
| CLK32K_FOUT_CTRL_GATING_REG | 0x0060                 | CLK32K Fanout Control register                   |
| GP_DATA_REGn                | 0x0100+N*0x004 (N=0-7) | General Purpose Register                         |
| FBOOT_INFO_REG0             | 0x0120                 | Fast Boot Info Register0                         |
| FBOOT_INFO_REG1             | 0x0124                 | Fast Boot Info Register1                         |
| DCXO_CTRL_WP_REG            | 0x015C                 | DCXO Control Write Protect Register              |
| DCXO_CTRL_REG               | 0x0160                 | DCXO Control Register                            |
| CALI_CTRL_REG               | 0x0164                 | Calibration Control Register                     |
| VDD_RTC_REG                 | 0x0190                 | VDD_RTC Regulation Register                      |
| IC_CHAR_REG                 | 0x01F0                 | IC Characteristic Register                       |
| VDD_OFF_GATING_CTRL_REG     | 0x01F4                 | VDD Off Gating Control Register                  |
| EFUSE_HV_PWR SWT_CTRL_REG   | 0x0204                 | Efuse High Voltage Power Switch Control Register |
| <b>VDD_SYS Power Domain</b> |                        |                                                  |
| RTC_SPI_CLK_CTRL_REG        | 0x0310                 | RTC SPI Clock Control Register                   |

## 2.12.6 Register Description

### 2.12.6.1 0x0000 LOSC Control Register (Default Value: 0x0000\_4010)

| Offset: 0x0000 |            |             | Register Name: LOSC_CTRL_REG                                                                                                        |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                         |
| 31:16          | W          | 0x0         | KEY_FIELD<br>KEY Field.<br>This field should be filled with 0x16AA, and then the bit 0 and bit 1 can be written with the new value. |

| Offset: 0x0000 |            |             | Register Name: LOSC_CTRL_REG                                                                                                                                                                                                                                                                                                                                |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                 |
| 15             | R/W        | 0x0         | LOSC_AUTO_SWT_FUNCTION<br>LOSC auto switch function disable.<br>0: Enable<br>1: Disable                                                                                                                                                                                                                                                                     |
| 14             | R/W        | 0x1         | LOSC_AUTO_SWT_32K_SEL_EN<br>LOSC auto switch 32K CLK source selection enable.<br>0: Disable. When the L OSC losts, 32k CLK source will not change to RC<br>1: Enable. When L OSC losts, 32k CLK source will change to RC (LOSC_SRC_SEL will be changed from 1 to 0)                                                                                         |
| 13:9           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                           |
| 8              | R          | 0x0         | RTC_HHMMSS_ACCE<br>RTC Hour Minute Second access.<br>After writing the RTC HH-MM-SS register, this bit is set and it will be cleared until the real writing operation is finished.<br>After writing the RTC HH-MM-SS register, the HH-MM-SS register will be refreshed for at most one second.<br>Note: Make sure that the bit is 0 for time configuration. |
| 7              | R          | 0x0         | RTC_DAY_ACCE<br>RTC DAY access.<br>After writing the RTC DAY register, this bit is set and it will be cleared until the real writing operation is finished.<br>After writing the RTC DAY register, the DAY register will be refreshed for at most one second.<br>Note: Make sure that the bit is 0 for time configuration.                                  |
| 6:5            | /          | /           | /                                                                                                                                                                                                                                                                                                                                                           |
| 4              | R/W        | 0x1         | EXT_LOSC_EN<br>External 32768Hz Crystal Enable.<br>0: disable<br>1: enable                                                                                                                                                                                                                                                                                  |
| 3:2            | R/W        | 0x0         | EXT_LOSC_GSM<br>External 32768Hz Crystal GSM.<br>00: Low<br>01: Reserved<br>10: Reserved                                                                                                                                                                                                                                                                    |

| Offset: 0x0000 |            |             | Register Name: LOSC_CTRL_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                |            |             | <p>11: High<br/>When GSM is changed, the 32K oscillation circuit will arise transient instability. If the auto switch function (bit 15) is enabled, 32K changes to RC16M with certain probability. The GSM can influence the time of 32K starting oscillation, the more the GSM, the shorter the time of starting oscillation. So modifying GSM is not recommended.</p> <p>If you need to modify the GSM, firstly disable the auto switch function (bit 15), with a delay of 50 us, then change the GSM, the 32K clock source is changed to external clock.</p> |
| 1              | R/W        | 0x0         | <p>RTC_SRC_SEL<br/>RTC_TIMER Clock Source Select.<br/>0: LOSC_SRC<br/>1: 24MDIV32K<br/>Before switching the bit, make sure that the 24MDIV32K function is enabled, that is, the bit16 of the <a href="#">32K Fanout Control Register</a> is 1.</p>                                                                                                                                                                                                                                                                                                              |
| 0              | R/W        | 0x0         | <p>LOSC_SRC_SEL<br/>LOSC Clock Source Select.<br/>'N' is the value of Internal OSC Clock Prescalar register.<br/>0: Low Frequency Clock from 16M RC<br/>1: External 32.768 kHz OSC.</p>                                                                                                                                                                                                                                                                                                                                                                         |

#### 2.12.6.2 0x0004 LOSC Auto Switch Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0004 |            |             | Register Name: LOSC_AUTO_SWT_STA_REG                                                                                                                                 |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                          |
| 31:3           | /          | /           | /                                                                                                                                                                    |
| 2              | R          | 0x0         | <p>EXT_LOSC_STA<br/>Work only when auto switch function is enable.<br/>0: External 32.768 kHz OSC work normally.<br/>1: External 32.768 kHz OSC work abnormally.</p> |
| 1              | R/W1C      | 0x0         | <p>LOSC_AUTO_SWT_PEND<br/>LOSC auto switch pending.<br/>0: No effect<br/>1: Auto switches pending, means LOSC_SRC_SEL is changed from 1 to 0.</p>                    |
| 0              | R          | 0x0         | LOSC_SRC_SEL_STA                                                                                                                                                     |

| Offset: 0x0004 |            |             | Register Name: LOSC_AUTO_SWT_STA_REG                                                                                                                                                |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                         |
|                |            |             | <p>Checking LOSC Clock Source Status.<br/> 'N' is the value of Internal OSC Clock Prescalar register.</p> <p>0: Low Frequency Clock from 16M RC<br/> 1: External 32.768 kHz OSC</p> |

#### 2.12.6.3 0x0008 Internal OSC Clock Prescalar Register (Default Value: 0x0000\_000F)

| Offset: 0x0008 |            |             | Register Name: INTOSC_CLK_PRESCAL_REG                                                                                                                                                        |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                  |
| 31:5           | /          | /           | /                                                                                                                                                                                            |
| 4:0            | R/W        | 0xF         | <p>INTOSC_32K_CLK_PRESCAL<br/> Internal OSC 32K Clock Prescalar value N<br/> The clock output = Internal RC/32 / N</p> <p>00000: 1<br/> 00001: 2<br/> 00002: 3<br/> .....<br/> 11111: 32</p> |

#### 2.12.6.4 0x000C Internal OSC Clock Auto Calibration Register (Default Value: 0x01E8\_0000)

| Offset: 0x000C |            |             | Register Name: INTOSC_CLK_AUTO_CALI_REG                                                                                                       |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                   |
| 31:22          | R          | 0x1E8       | 32k calibration integer divide factor.                                                                                                        |
| 21:5           | R          | 0x0         | 32k calibration decimal divide factor.                                                                                                        |
| 4              | R/W        | 0x0         | <p>Calibration function Clk16M_RC_enable<br/> 0: Auto gating<br/> 1: Soft bypass</p>                                                          |
| 3:2            | R/W        | 0x0         | <p>RC Calibration Precise Selection<br/> 00: 1ms calibration precise<br/> 01: 16ms calibration precise<br/> 10: 128ms calibration precise</p> |
| 1              | R/W        | 0x0         | <p>RC calibration enable<br/> 0: Close Calibration circuit<br/> 1: Open Calibration circuit</p>                                               |
| 0              | R/W        | 0x0         | <p>RC CLK SRC SEL<br/> Select the RTC 32k clock source from normal RC or Calibrated RC:<br/> 0: Normal RC</p>                                 |

| Offset: 0x000C |            |             | Register Name: INTOSC_CLK_AUTO_CALI_REG |
|----------------|------------|-------------|-----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                             |
|                |            |             | 1: Calibrated RC                        |

#### 2.12.6.5 0x0010 RTC Year-Month-DAY Register (Default Value: 0x0000\_0000)

| Offset: 0x0010 |            |             | Register Name: RTC_DAY_REG             |
|----------------|------------|-------------|----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                            |
| 31:16          | /          | /           | /                                      |
| 15:0           | R/W        | UDF         | DAY<br>Set DAY.<br>Range from 0-65535. |

#### 2.12.6.6 0x0014 RTC Hour-Minute-Second Register (Default Value: 0x0000\_0000)

| Offset: 0x0014 |            |             | Register Name: RTC_HH_MM_SS_SET_REG      |
|----------------|------------|-------------|------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                              |
| 31:21          | /          | /           | /                                        |
| 20:16          | R/W        | UDF         | HOUR<br>Set Hour.<br>Range from 0-23     |
| 15:14          | /          | /           | /                                        |
| 13:8           | R/W        | UDF         | MINUTE<br>Set Minute.<br>Range from 0-59 |
| 7:6            | /          | /           | /                                        |
| 5:0            | R/W        | UDF         | SECOND<br>Set second.<br>Range from 0-59 |

#### 2.12.6.7 0x0020 Alarm 0 Day Set Register (Default Value: 0x0000\_0000)

| Offset: 0x0020 |            |             | Register Name: ALARM0_DAY_SET_REG                  |
|----------------|------------|-------------|----------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                        |
| 31:16          | /          | /           | /                                                  |
| 15:0           | R/W        | 0x0         | ALARM0_COUNTER<br>Alarm 0 Counter is Based on Day. |

#### 2.12.6.8 0x0024 Alarm 0 Counter Current Value Register (Default Value: 0x0000\_0000)

|                |                                   |
|----------------|-----------------------------------|
| Offset: 0x0024 | Register Name: ALARM0_CUR_VLU_REG |
|----------------|-----------------------------------|

| Bit   | Read/Write | Default/Hex | Description                                  |
|-------|------------|-------------|----------------------------------------------|
| 31:21 | /          | /           | /                                            |
| 20:16 | R/W        | UDF         | HOUR<br>Current hour.<br>Range from 0-23     |
| 15:14 | /          | /           | /                                            |
| 13:8  | R/W        | UDF         | MINUTE<br>Current minute.<br>Range from 0-59 |
| 7:6   | /          | /           | /                                            |
| 5:0   | R/W        | UDF         | SECOND<br>Current second.<br>Range from 0-59 |

#### 2.12.6.9 0x0028 Alarm 0 Enable Register (Default Value: 0x0000\_0000)

| Offset: 0x0028 |            |             | Register Name: ALARM0_ENABLE_REG                       |
|----------------|------------|-------------|--------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                            |
| 31:1           | /          | /           | /                                                      |
| 0              | R/W        | 0x0         | ALM_0_EN<br>Alarm 0 Enable.<br>0: Disable<br>1: Enable |

#### 2.12.6.10 0x002C Alarm 0 IRQ Enable Register (Default Value: 0x0000\_0000)

| Offset: 0x002C |            |             | Register Name: ALARM0_IRQ_EN                                    |
|----------------|------------|-------------|-----------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                     |
| 31:1           | /          | /           | /                                                               |
| 0              | R/W        | 0x0         | ALARM0_IRQ_EN<br>Alarm 0 IRQ Enable.<br>0: Disable<br>1: Enable |

#### 2.12.6.11 0x0030 Alarm 0 IRQ Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0030 |            |             | Register Name: ALARM0_IRQ_STA_REG           |
|----------------|------------|-------------|---------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                 |
| 31:1           | /          | /           | /                                           |
| 0              | R/W1C      | 0x0         | ALARM0_IRQ_PEND<br>Alarm 0 IRQ Pending bit. |

| Offset: 0x0030 |            |             | Register Name: ALARM0_IRQ_STA_REG                                                                                                                            |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                  |
|                |            |             | 0: No effect<br>1: Pending, alarm 0 counter value is reached<br>If alarm 0 IRQ enable is set to 1, the pending bit will be sent to the interrupt controller. |

#### 2.12.6.12 0x0050 Alarm 0 Configuration Register (Default Value: 0x0000\_0000)

| Offset: 0x0050 |            |             | Register Name: ALARM0_CONFIG_REG                                                                                             |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                  |
| 31:1           | /          | /           | /                                                                                                                            |
| 0              | R/W        | 0x0         | ALARM0_WAKEUP<br>Configuration of alarm wake up output.<br>0: Disable alarm wake up output<br>1: Enable alarm wake up output |

#### 2.12.6.13 0x0060 CLK32K Fanout Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0060 |            |             | Register Name: CLK32K_FOUT_CTRL_GATING_REG                                                                                                                                  |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                 |
| 31:17          | /          | /           | /                                                                                                                                                                           |
| 16             | R/W        | 0x0         | DCXO_TO_32K_DIVIDER_ENABLE<br>DCXO to 32k divider enable.<br>1: Enable the DCXO 24M to 32K divider circuit<br>0: Disable the DCXO 24M to 32K divider circuit                |
| 15:3           | /          | /           | /                                                                                                                                                                           |
| 2:1            | R/W        | 0x0         | LOSC_OUT_SRC_SEL<br>LOSC Output Source Select.<br>00: RTC_32K (select by RC_CLK_SRC_SEL & LOSC_SRC_SEL)<br>01: LOSC<br>10: DCXO divided 32K                                 |
| 0              | R/W        | 0x0         | LOSC_OUT_GATING<br>LOSC Output Gating Enable.<br>Configuration of LOSC output, and no LOSC output by default.<br>0: Mask LOSC output gating<br>1: Enable LOSC output gating |

#### 2.12.6.14 0x0100+N\*0x0004 (N=0-7) General Purpose Register (Default Value: 0x0000\_0000)

| Offset: 0x0100+N*0x0004 (N=0-7) |            |             | Register Name: GP_DATA_REGn |
|---------------------------------|------------|-------------|-----------------------------|
| Bit                             | Read/Write | Default/Hex | Description                 |
| 31:0                            | R/W        | 0x0         | GP_DATA<br>Data.            |



##### NOTE

General purpose register 0 to 7 value can be stored if the RTC-VI O is larger than 0.7 V.

#### 2.12.6.15 0x0120 Fast Boot Info Register0 (Default Value: 0x0000\_0000)

| Offset: 0x0120 |            |             | Register Name: FBOOT_INFO_REG0                                                |
|----------------|------------|-------------|-------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                   |
| 31:0           | R/W        | 0x0         | FBOOT_INFO0.<br>Fast Boot info.<br>Fast Boot Information, refer to BROM spec. |

#### 2.12.6.16 0x0124 Fast Boot Info Register1 (Default Value: 0x0000\_0000)

| Offset: 0x0124 |            |             | Register Name: FBOOT_INFO_REG1                                                |
|----------------|------------|-------------|-------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                   |
| 31:0           | R/W        | 0x0         | FBOOT_INFO1.<br>Fast boot info.<br>Fast Boot Information, refer to BROM spec. |

#### 2.12.6.17 0x015C DCXO Control Write Protect Register (Default Value: 0x0000\_0000)

| Offset: 0x015C |            |             | Register Name: DCXO_CTRL_WP_REG                                                                                                                                                                                          |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                              |
| 31:16          | /          | /           | /                                                                                                                                                                                                                        |
| 15:0           | R/W        | 0x0         | Key Filed.<br>Write protection for XO_CTRL_REG(0x0160).<br>Write this field as 0x16AA before configuring<br>XO_CTRL_REG(0x0160) and this field will be<br>automatically cleared to 0 after XO_CTRL_REG is<br>configured. |

## 2.12.6.18 0x0160 DCXO Control Register (Default Value: 0x983F\_10F7)

| Offset: 0x0160 |            |             | Register Name: DCXO_CTRL_REG                                                                                                                            |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                             |
| 31             | R/W        | 0x1         | CLK_REQ_ENB<br>CLK REQ Enable<br>0: Enable DCXO wake up function<br>1: Disable DCXO wake up function                                                    |
| 30:29          | /          | /           | /                                                                                                                                                       |
| 28             | R          | 0x1         | DCXO_STABLE_STS<br>DCXO Stable Status<br>0: no stable<br>1: stable                                                                                      |
| 27:24          | R/W        | 0x8         | DCXO_ICTRL<br>DCXO current control value.                                                                                                               |
| 23             | /          | /           | /                                                                                                                                                       |
| 22:16          | R/W        | 0x3F        | DCXO_TRIM<br>DCXO cap array value.<br>cap cell is 55fF                                                                                                  |
| 15:13          | /          | /           | /                                                                                                                                                       |
| 12:8           | R/W        | 0x10        | DCXO_BG<br>DCXO bandgap output voltage.                                                                                                                 |
| 7              | R/W        | 0x1         | DCXO_LDO_INRUSHB<br>DCXO LDO driving capacity signal active high.                                                                                       |
| 6              | R/W        | 0x1         | XTAL_MODE<br>XTAL mode enable signal active high.<br>0x0 for external CLK input mode.<br>0x1 for normal mode.                                           |
| 5:4            | R/W        | 0x3         | DCXO_RFCLK_ENHANCE<br>DCXO RFCLK Enhance.<br>Enhance driving capacity of output OUT_RF_REFCLK,<br>0x0 for 5pF, 0x1 for 10pF, 0x2 for 15pF, 0x3 for 20pF |
| 3              | /          | /           | /                                                                                                                                                       |
| 2              | R/W        | 0x1         | RSTO_DLY_SEL<br>RSTO delay select.<br>For Debug Use Only<br>It cannot configure to 0 in normal state.                                                   |
| 1              | R/W        | 0x1         | DCXO_EN<br>DCXO Enable.<br>1: Enable<br>0: Disable                                                                                                      |
| 0              | R/W        | 0x1         | CLK16M_RC_EN<br>Clock RC16M Enable.                                                                                                                     |

| Offset: 0x0160 |            |             | Register Name: DCXO_CTRL_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                |            |             | <p>1: Enable<br/>0: Disable</p> <p>The related register configuration is necessary to ensure the reset debounce circuit has a stable clock source.</p> <p>The first time SoC starts up, by default, the reset debounce circuit of SoC uses 32K divided by RC16M. In power-off, software reads the related bit to ensure whether EXT32K is working normally, if it is normal, first switch the clock source of debounce circuit to EXT32K, then close RC16M.</p> <p>Without EXT32K scenario or external RTC scenario, software confirms firstly whether EXT32K is working normally before switching, or software does not close RC16M.</p> |

#### 2.12.6.19 0x0164 Calibration Control Register (Default Value: 0x0000\_0043)

| Offset: 0x0164 |            |             | Register Name: CALI_CTRL_REG                                                                                                                                                         |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                          |
| 31             | R/W        | 0x0         | <p>WAKEUP_DCXO_EN</p> <p>Wake up DCXO circuit enable.</p>                                                                                                                            |
| 30:17          | /          | /           | /                                                                                                                                                                                    |
| 16             | R/W        | 0x0         | <p>WAKEUP_READY_SLEEP_MODE</p> <p>Calibration wake up ready sleep mode, it must be set before 0x164 bit31 WAKEUP_DCXO_EN is set to 1.</p> <p>0: Disable<br/>1: Enable</p>            |
| 15:12          | R/W        | 0x0         | <p>TIMER FOR READY SLEEP</p> <p>Total timer for ready sleep</p> <p>0x00: 15s<br/>0x01: 30s<br/>0x02: 45s<br/>0x03: 60s<br/>0x04: 90s<br/>0x05: 120s<br/>0x06: 150s<br/>Others: /</p> |
| 11:8           | R/W        | 0x0         | <p>WAKEUP_CNT FOR READY SLEEP</p> <p>Wake up counter for ready sleep</p> <p>0x00: 250ms</p>                                                                                          |

| Offset: 0x0164 |            |             | Register Name: CALI_CTRL_REG                                                                                                                                                                                                                                                             |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                              |
|                |            |             | 0x01: 500ms<br>0x02: 750ms<br>0x03: 1s<br>0x04: 1.25s<br>0x05: 1.5s<br>0x06: 1.75s<br>0x07: 2s<br>0x08: 2.25s<br>0x09: 2.5s<br>0x0A: 2.75s<br>0x0B: 3s<br>0x0C: 3.25s<br>0x0D: 3.5s<br>0x0E: 3.75s<br>0x0F: 4s                                                                           |
| 7:4            | R/W        | 0x4         | <b>WAKEUP_CNT FOR SLEEP</b><br>Wake up counter for sleep<br>0x00: 250ms<br>0x01: 500ms<br>0x02: 1s<br>0x03: 10s<br>0x04: 60s<br>0x05: 120s<br>0x06: 180s<br>0x07: 240s<br>0x08: 300s<br>0x09: 360s<br>0x0A: 420s<br>0x0B: 480s<br>0x0C: 540s<br>0x0D: 600s<br>0x0E: 1200s<br>0x0F: 1800s |
| 3:0            | R/W        | 0x3         | <b>WAIT DCXO SEL</b><br>Select for DCXO active after DCXO enable<br>0x0: 1ms<br>0x1: 2ms<br>0x2: 3ms<br>0x3: 4ms<br>...<br>0xF: 16ms                                                                                                                                                     |

#### 2.12.6.20 0x0190 VDD RTC Regulation Register (Default Value: 0x0000\_0004)

| Offset: 0x0190 |            |             | Register Name: VDD_RTC_REG                                                                                                                                                                                                                                                               |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                              |
| 31:5           | /          | /           | /                                                                                                                                                                                                                                                                                        |
| 4              | R/W        | 0x0         | V_SEL<br>VDD Select<br>0: Resistance divider<br>1: Band gap                                                                                                                                                                                                                              |
| 3              | /          | /           | /                                                                                                                                                                                                                                                                                        |
| 2:0            | R/W        | 0x4         | VDD_RTC_REGU<br>RTC VIO voltage select<br>The RTC-VIO is provided power for RTC digital part.<br>These bits are useful for regulating the RTC_VIO from 0.65 V to 1.3 V:<br>0x0: 1.0 V<br>0x1: 0.65 V<br>0x2: 0.7 V<br>0x3: 0.8 V<br>0x4: 0.9 V<br>0x5: 1.1 V<br>0x6: 1.2 V<br>0x7: 1.3 V |

#### 2.12.6.21 0x01F0 IC Characteristic Register (Default Value: 0x0000\_0000)

| Offset: 0x01F0 |            |             | Register Name: IC_CHARA_REG                                                                                                         |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                         |
| 31:16          | R/W        | 0x0         | KEY_FIELD<br>Write protect.<br>Should be written at value 0x16AA. Writing any other value in this field aborts the write operation. |
| 15:0           | R/W        | 0x0         | ID_DATA<br>IC_CHARA.<br>Return 0x16AA only if the KEY_FIELD is set as 0x16AA when read those bits, otherwise return 0x0.            |

#### 2.12.6.22 0x01F4 VDD Off Gating Control Register (Default Value: 0x0000\_0021)

| Offset: 0x01F4 |            |             | Register Name: VDD_OFF_GATING_CTRL_REG |
|----------------|------------|-------------|----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                            |
| 31:16          | W          | 0x0         | KEY_FIELD                              |

| Offset: 0x01F4 |            |             | Register Name: VDD_OFF_GATING_CTRL_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                |            |             | Write protect.<br>This field should be filled with 0x16AA, and then the bit 15 can be configured.                                                                                                                                                                                                                                                                                                                                                                                                  |
| 15             | WAC        | 0x0         | PWROFF_GAT_RTC_CFG.<br>Power off gating control signal.<br>When use VDD-SYS to RTC isolation software control, write this bit 1, it will only be clear by RESETB release.<br>(For Debug Use Only)                                                                                                                                                                                                                                                                                                  |
| 14:12          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 11:4           | R/W        | 0x2         | VCCIO_DET_SPARE<br>VCCIO detect spare.<br>Bit [7:5]: Reserved<br>Bit [4]: Bypass debounce circuit<br>0: bypass<br>1: no bypass<br>Bit [3]: Enable control<br>0: Disable VCC-IO detector<br>1: Force the detection output<br>Bit [2:0]: Gear adjustment<br>000: Detection threshold is 2.5 V<br>001: Detection threshold is 2.6 V<br>010: Detection threshold is 2.7 V<br>011: Detection threshold is 2.8 V<br>100: Detection threshold is 2.9 V<br>101: Detection threshold is 3 V<br>110-111: N/A |
| 3:1            | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 0              | R/W        | 0x1         | VCCIO_DET_BYPASS_EN<br>VCCIO detect bypass enable.<br>0: not bypass<br>1: bypass                                                                                                                                                                                                                                                                                                                                                                                                                   |

#### 2.12.6.23 0x0204 eFuse High Voltage Power Switch Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0204 |            |             | Register Name: EFUSE_HV_PWR SWT_CTRL_REG                                              |
|----------------|------------|-------------|---------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                           |
| 31:1           | /          | /           | /                                                                                     |
| 0              | R/W        | 0x0         | EFUSE_1P8V_POWER_SWITCH_CONTROL<br>EFUSE power switch control<br>1: open power switch |

| Offset: 0x0204 |            |             | Register Name: EFUSE_HV_PWRSWT_CTRL_REG |
|----------------|------------|-------------|-----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                             |
|                |            |             | 0: close power switch                   |

#### 2.12.6.24 0x0310 RTC SPI Clock Control Register (Default Value: 0x0000\_0009)

| Offset: 0x0310 |            |             | Register Name: RTC_SPI_CLK_CTRL_REG                                                                                                                                                                                                                                                                    |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                            |
| 31             | R/W        | 0x0         | <p>RTC_SPI_GATE_EN<br/>RTC Reg CFG SPI Clock Gating.<br/>0: Gating<br/>1: Not Gating<br/>Before configuring RTC register, the clock divider of SPI needs be configured firstly, then clock gating needs be enabled.<br/>Note: Frequency division and clock gating can not be set at the same time.</p> |
| 30:5           | /          | /           | /                                                                                                                                                                                                                                                                                                      |
| 4:0            | R/W        | 0x9         | <p>RTC_SPI_DIV<br/>RTC Reg CFG SPI Clock Divider M.<br/>Actual SPI Clock = AHBS1/(M+1), (0 to 15)<br/>The default frequency of AHBS1 is 200 MHz, and the default frequency of SPI Clock is 20 MHz.<br/>Note: The SPI clock can not exceed 50 MHz, or else the RTC register may be abnormal.</p>        |

## 2.13 Spinlock

### 2.13.1 Overview

The spinlock provides hardware synchronization mechanism in multi-core systems. With the lock operation, the spinlock prevents multiple processors from handling the sharing data simultaneously and thus ensure the coherence of data.

The spinlock has the following features:

- Supports 32 lock units
- Two kinds of lock status: locked and unlocked
- Lock time of the processor is predictable (less than 200 cycles)

### 2.13.2 Block Diagram

The following figure shows the block diagram of the spinlock.

Figure 2-37 Spinlock Block Diagram



### 2.13.3 Functional Description

#### 2.13.3.1 Clock and Reset

The spinlock is mounted on AHB. Before accessing the spinlock registers, you need to de-assert the reset signal on AHB bus and then open the corresponding gating signal on AHB bus.

#### 2.13.3.2 Typical Application

The following figure shows a typical application of the spinlock. A processor locks spinlock0 before executing specific codes, and then unlocks the codes. After the lock is freed, other processors can read or write the data.

Figure 2-38 Spinlock Typical Application Diagram



### 2.13.3.3 Spinlock State Machine

When a processor uses spinlock, it needs to acquire the spinlock status through [SPINLOCK\\_STATUS\\_REG](#).

#### Reading operation

when the return value is 0, it indicates that the spinlock enters the locked status; reading this status bit again can return 1, it indicates that the spinlock is the locked status.

#### Writing operation

when the spinlock is in the locked status, writing 0 can convert the spinlock to the unlocked status, the writing operation for other status is invalid.

The following figure shows the spinlock state machine.

Figure 2-39 Spinlock State Machine



- When the spinlock is in the unlocked state, writing 0/1 has no effect;
- When the spinlock is in the locked state, writing 0 can convert the corresponding spinlock to the unlocked state;
- When the spinlock is in the locked state, writing 1 has no effect;
- When the spinlock is in the unlocked state, reading the bit can return 0 (it indicates spinlock enters into the locked state);
- When the spinlock is in the locked state, reading the bit can return 1 (it indicates spinlock is in the locked state);
- After reset, the spinlock is in the unlock state by default.

## 2.13.4 Programming Guidelines

### 2.13.4.1 Switching the Status

Follow the steps below to switch the lock status of a spinlock.

- Step 1 When the read value from [SPINLOCKN\\_LOCK\\_REG \(N=0~31\)](#) is 0, the spinlock comes into the locked status.
- Step 2 Execute the application codes, and the status of [SPINLOCK\\_STATUS\\_REG](#) is 1.
- Step 3 Write 0 to [SPINLOCKN\\_LOCK\\_REG \(N=0~31\)](#), the spinlock converts into the unlocked status, and the corresponding spinlock is released.

### 2.13.4.2 Processing the Interrupt

The spinlock generates an interrupt when a lock is freed (the lock status converts from the locked status to the unlocked status).

Follow the steps below to process the interrupt:

- Step 1** Configure the interrupt enable bit of the corresponding spinlock in [SPINLOCK\\_IRQ\\_EN\\_REG](#) to enable the interrupt.
- Step 2** The spinlock generates an interrupt when its status converts from the locked status to the unlocked status, and the corresponding bit of the [SPINLOCK\\_IRQ\\_STA\\_REG](#) turns to 1.
- Step 3** Execute the interrupt handle function and clear the pending bit.

#### 2.13.4.3 Taking/Freeing Spinlock

Take the synchronization between CPUX and RISCV with Spinlock0 as an example, the CPUX and RISCV perform the following steps.

**Figure 2-40 CPUX and RISCV Taking/Freeing Spinlock0 Process**



#### CPUX:

- a) The CPUX initializes Spinlock.
- b) Check lock register0 (SPINLOCK\_STATUS\_REG0) status. If it is taken, check until CPUX frees spinlock0 and then request to take spinlock0. Otherwise, retry until the lock register0 is taken.
- c) Execute CPUX critical code.
- d) After executing CPUX critical code, the CPUX frees spinlock0.

The CPUX waits for RISCV to free spinlock0.

#### RISCV:

- a) If the CPUX has taken spinlock0, the RISCV waits for CPUX to free spinlock0.
- b) The RISCV requests to take spinlock0. If it fails, retry until the lock register0 is taken.
- c) Execute RISCV critical code.

- d) After executing RISCV critical code, the RISCV frees spinlock0.

The following codes are for reference.

-----CPUX-----

**Step 1** CPUX initializes Spinlock

```
put_wvalue(SPINLOCK_BGR_REG,0x00010000);
put_wvalue(SPINLOCK_BGR_REG,0x00010001);
```

**Step 2** CPUX requests to take spinlock0

```
rdata=readl(SPINLOCK_STATUS_REG0);           //Check lock register0 status
if (rdata != 0) writel (0, SPINLOCK_LOCK_REG0); //If it is taken, check till CPUX frees spinlock0
rdata=readl(SPINLOCK_LOCK_REG0);             //Request to take spinlock0
if (rdata != 0) rdata=readl(SPINLOCK_LOCK_REG0); //If it fails, retry till lock register0 is
taken
```

-----CPUX critical code section-----

**Step 3** CPUX frees spinlock0

```
writel (0, SPINLOCK_LOCK_REG0);           //CPUX frees spinlock0
```

**Step 4** CPUX waits for RISCV' freeing spinlock0

```
writel(readl(SPINLOCK_STATUS_REG0) == 1); //CPUX waits for RISCV' freeing spinlock0
```

-----RISCV-----

**Step 1** CPUX has taken spinlock0, RISCV waits for CPUX' freeing spinlock0

```
while(readl(SPINLOCK_STATUS_REG0) == 1); //RISCV waits for CPUX' freeing spinlock0
```

**Step 2** RISCV takes spinlock0 and go on

```
rdata=readl(SPINLOCK_LOCK_REG0);           //Request to take spinlock0
if (rdata != 0) rdata=readl(SPINLOCK_LOCK_REG0); //If it fails, retry till lock register0 is
taken
```

-----RISCV critical code section-----

**Step 3** RISCV frees spinlock0

```
writel (0, SPINLOCK_LOCK_REG0);           //RISCV frees spinlock0
```

## 2.13.5 Register List

| Module Name | Base Address |
|-------------|--------------|
| SPINLOCK    | 0x03005000   |
| S_SPINLOCK  | 0x07093000   |

| Register Name         | Offset            | Description                        |
|-----------------------|-------------------|------------------------------------|
| SPINLOCK_SYSTATUS_REG | 0x0000            | Spinlock System Status Register    |
| SPINLOCK_STATUS_REG   | 0x0010            | Spinlock Status Register           |
| SPINLOCK_IRQ_EN_REG   | 0x0020            | Spinlock Interrupt Enable Register |
| SPINLOCK_IRQ_STA_REG  | 0x0040            | Spinlock Interrupt Status Register |
| SPINLOCK_LOCKID0_REG  | 0x0080            | Spinlock Lockid0 Register          |
| SPINLOCK_LOCKID1_REG  | 0x0084            | Spinlock Lockid1 Register          |
| SPINLOCK_LOCKID2_REG  | 0x0088            | Spinlock Lockid2 Register          |
| SPINLOCK_LOCKID3_REG  | 0x008C            | Spinlock Lockid3 Register          |
| SPINLOCK_LOCKID4_REG  | 0x0090            | Spinlock Lockid4 Register          |
| SPINLOCK_LOCK_REGN    | 0x0100 + N*0x0004 | Spinlock Register N (N = 0 to 31)  |

## 2.13.6 Register Description

### 2.13.6.1 0x0000 Spinlock System Status Register (Default Value: 0x1000\_0000)

| Offset: 0x0000 |            |             | Register Name: SPINLOCK_SYSTATUS_REG                                                                                                                                                                                            |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                     |
| 31:30          | /          | /           | /                                                                                                                                                                                                                               |
| 29:28          | R          | 0x1         | LOCKS_NUM<br>Number of lock registers implemented<br>00: This instance has 256 lock registers<br>01: This instance has 32 lock registers<br>10: This instance has 64 lock registers<br>11: This instance has 128 lock registers |
| 27:9           | /          | /           | /                                                                                                                                                                                                                               |
| 8              | R          | 0x0         | IU0<br>In-Use flag0, covering lock register0-31<br>0: All lock registers 0-31 are in the NotTaken state.<br>1: At least one of the lock register 0-31 is in the Taken state.                                                    |
| 7:0            | /          | /           | /                                                                                                                                                                                                                               |

### 2.13.6.2 0x0010 Spinlock Register Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0010 |            |             | Register Name: SPINLOCK_STATUS_REG                               |
|----------------|------------|-------------|------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                      |
| 31:0           | R          | 0x0         | LOCK_REG_STATUS<br>SpinLock[i] status<br>0: The Spinlock is free |

| Offset: 0x0010 |            |             | Register Name: SPINLOCK_STATUS_REG |
|----------------|------------|-------------|------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                        |
|                |            |             | 1: The Spinlock is taken           |

#### 2.13.6.3 0x0020 Spinlock Interrupt Enable Register (Default Value: 0x0000\_0000)

| Offset: 0x0020 |            |             | Register Name: SPINLOCK_IRQ_EN_REG                                     |
|----------------|------------|-------------|------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                            |
| 31:0           | R/W        | 0x0         | LOCK_IRQ_EN<br>SpinLock[i] interrupt enable<br>0: Disable<br>1: Enable |

#### 2.13.6.4 0x0040 Spinlock Interrupt Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0040 |            |             | Register Name: SPINLOCK_IRQ_STA_REG                                                                         |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                 |
| 31:0           | R/W1C      | 0x0         | LOCK_IRQ_STATUS<br>SpinLock[i] interrupt status<br>0: No effect<br>1: Pending<br>Writing 1 clears this bit. |

#### 2.13.6.5 0x0080 Spinlock Lockid0 Register (Default Value: 0x7777\_7777)

| Offset: 0x0080 |            |             | Register Name: SPINLOCK_LOCKIN0_REG |
|----------------|------------|-------------|-------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                         |
| 31:0           | R          | 0x77777777  | LOCKID0                             |

#### 2.13.6.6 0x0084 Spinlock Lockid1 Register (Default Value: 0x7777\_7777)

| Offset: 0x0084 |            |             | Register Name: SPINLOCK_LOCKIN1_REG |
|----------------|------------|-------------|-------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                         |
| 31:0           | R          | 0x77777777  | LOCKID1                             |

#### 2.13.6.7 0x0088 Spinlock Lockid2 Register (Default Value: 0x7777\_7777)

| Offset: 0x0088 |            |             | Register Name: SPINLOCK_LOCKIN2_REG |
|----------------|------------|-------------|-------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                         |
| 31:0           | R          | 0x77777777  | LOCKID2                             |

#### 2.13.6.8 0x008C Spinlock Lockid3 Register (Default Value: 0x7777\_7777)

| Offset: 0x008C |            |             | Register Name: SPINLOCK_LOCKIN3_REG |
|----------------|------------|-------------|-------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                         |
| 31:0           | R          | 0x77777777  | LOCKID3                             |

#### 2.13.6.9 0x0090 Spinlock Lockid4 Register (Default Value: 0x7777\_7777)

| Offset: 0x0090 |            |             | Register Name: SPINLOCK_LOCKIN4_REG |
|----------------|------------|-------------|-------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                         |
| 31:0           | R          | 0x77777777  | LOCKID4                             |

#### 2.13.6.10 0x0100 + N\*0x04 Spinlock Register N (N = 0 to 31) (Default Value: 0x0000\_0000)

| Offset: 0x0100 + N*0x0004 (N = 0 to 31) |            |             | Register Name: SPINLOCKN_LOCK_REG                                                                                                                                                                                                                                                                          |
|-----------------------------------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                                     | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                |
| 31:1                                    | /          | /           | /                                                                                                                                                                                                                                                                                                          |
| 0                                       | R/W        | 0x0         | TAKEN<br>Lock State<br>Read 0x0: The lock was previously Not Taken (free). The requester is granted the lock.<br>Write 0x0: Set the lock to Not Taken (free).<br>Read 0x1: The lock was previously Taken. The requester is not granted the lock and must retry.<br>Write 0x1: No update to the lock value. |

## 2.14 Thermal Sensor Controller (THS)

### 2.14.1 Overview

The thermal sensors are common elements in wide range of modern system on chips (SoCs) platform. The thermal sensors are used to constantly monitor the temperature on the chip.

The thermal sensor controller (THS) embeds four thermal sensors. TSENSOR0 is located in the 'big' cores of CPUX; TSENSOR1 is located in the 'LITTLE' cores of CPUX; TSENSOR2 is located in the GPU; TSENSOR4 is located in the DDR. When the temperature reaches a certain thermal threshold, the thermal sensor can generate interrupts to the software to lower the temperature via the dynamic voltage and frequency scaling (DVFS) technology.

The THS has the following features:

- Two THS controllers
  - THS0, including TSENSOR4
  - THS1, including TSENSOR0, TSENSOR1, and TSENSOR2
- Temperature accuracy:  $\pm 5^{\circ}\text{C}$  from  $-40^{\circ}\text{C}$  to  $60^{\circ}\text{C}$ ,  $\pm 3^{\circ}\text{C}$  from  $-60^{\circ}\text{C}$  to  $+125^{\circ}\text{C}$
- Averaging filter for thermal sensor reading
- Supports over-temperature protection interrupt and over-temperature alarm interrupt

### 2.14.2 Block Diagram

The following figures show the block diagrams of the THS0 and THS1.

Figure 2-41 THS0 Block Diagram



Figure 2-42 THS1 Block Diagram



## 2.14.3 Functional Description

### 2.14.3.1 Clock Source

Both of THS0 and THS1 get two clock sources: DCXO24M and PCLK. For details about clock configurations, refer to section 2.5 Clock Controller Unit (CCU).

### 2.14.3.2 Timing Requirements

The following figure shows the timing requirements for the THS module.

Figure 2-43 Thermal Sensor Timing Requirement



$\text{CLK\_IN} = 24 \text{ MHz}$

$\text{CONV\_TIME} (\text{Conversion Time}) = 1/24 \text{ MHz} \times 14 \text{ Cycles} = 0.583 \text{ us}$

$\text{TACQ} > 1/24 \text{ MHz} \times 24 \text{ Cycles}$

$\text{THERMAL\_PER} > \text{ADC\_Sample\_Frequency} > \text{TACQ} + \text{CONV\_TIME}$

### 2.14.3.3 Interrupts

The THS module has four interrupt sources: DATA\_IRQ, SHUTDOWN\_IRQ, ALARM\_IRQ, and ALARM\_OFF\_IRQ. The following figure shows thermal sensor interrupt sources.

Figure 2-44 Thermal Sensor Controller Interrupt Source



#### DATA\_IRQ

The interrupt is generated when the measured sensor\_data is updated.

#### SHUTDOWN\_IRQ

The interrupt is generated when the temperature is higher than the shutdown threshold.

#### ALARM\_IRQ

The interrupt is generated when the temperature is higher than the Alarm\_Threshold.

#### ALARM\_OFF\_IRQ

The interrupt is generated when the temperature drops to lower than the Alarm\_Off\_Threshold. It is triggered at the fall edge.

### 2.14.3.4 THS Temperature Conversion Formula

$$-40^{\circ}\text{C} \text{ to } +55^{\circ}\text{C}: T = (\text{sensor\_data} - 2736) / (-13.54)$$

$$+55^{\circ}\text{C} \text{ to } 125^{\circ}\text{C}: T = (\text{sensor\_data} - 2825) / (-15.33)$$

Unit of T: Celsius degree ( $^{\circ}\text{C}$ ).

The sensor\_data is read from the sensor data register.

## 2.14.4 Programming Guidelines

The initial process of the THS is as follows.

**Figure 2-45 THS Initial Process**



In the final test (FT) stage, the THS is calibrated through the ambient temperature, and the calibration value is written in the SID module. The following table shows the THS0 and THS1 information in the SID.

**Table 2-21 THS Information in the SID**

| eFuse Name              | Base Address           | Bit   | Description                       |
|-------------------------|------------------------|-------|-----------------------------------|
| T-sensor<br>Calibration | 0x3B-0x3F<br>(72 bits) | 35-24 | The calibration value of TSENSOR0 |
|                         |                        | 23-12 | The calibration value of TSENSOR1 |
|                         |                        | 11-0  | ROOM                              |
|                         | 0x44-0x48<br>(72 bits) | 35-24 | The calibration value of TSENSOR4 |
|                         |                        | 11-0  | The calibration value of TSENSOR2 |

Before enabling THS, read eFuse value and write the value to TSENSORn\_CDATA (n=0, 1, 2, or 4).

### Query Mode

The following takes THS0 as an example, THS0 and THS1 are the same.

- Step 1** Write 0x1 to the bit [16] of [THS\\_BGR\\_REG](#) to dessert the reset.
- Step 2** Write 0x1 to the bit [0] of [THS\\_BGR\\_REG](#) to open the THS clock.
- Step 3** Write 0x2F to the bit [15:0] of [THS0\\_CTRL](#) to set the ADC acquire time.
- Step 4** Write 0x1DF to the bit [31:16] of [THS0\\_CTRL](#) to set the ADC sample frequency divider.
- Step 5** Write 0x3A to the bit [31:12] of [THS0\\_PER](#) to set the THS work period.
- Step 6** Write 0x1 to the bit [2] of [THS0\\_FILTER](#) to enable the temperature convert filter.

- Step 7** Write 0x1 to the bit [1:0] of [THS0\\_FILTER](#) to select the filter type.
- Step 8** Read THS eFuse value from SID, then write the eFuse value to [TSENSOR4\\_CDATA](#) to calibrate THS.
- Step 9** Write 0x1 to the bit [0] of [THS0\\_EN](#) to enable THS.
- Step 10** Read the bit [0] of [THS0\\_DATA\\_INTS](#). If it is 1, the temperature conversion is complete.
- Step 11** Read the bit [11:0] of [TSENSOR4\\_DATA](#), and calculate the THS temperature based on section 2.14.3.4 THS Temperature Conversion Formula.

#### Interrupt Mode

The following takes THS0 as an example, THS0 and THS1 are the same.

- Step 1** Write 0x1 to the bit16 of [THS\\_BGR\\_REG](#) to dessert the reset.
- Step 2** Write 0x1 to the bit0 of [THS\\_BGR\\_REG](#) to open the THS clock.
- Step 3** Write 0x2F to the bit [15:0] of [THS0\\_CTRL](#) to set the ADC acquire time.
- Step 4** Write 0x1DF to the bit [31:16] of [THS0\\_CTRL](#) to set the ADC sample frequency divider.
- Step 5** Write 0x3A to the bit [31:12] of [THS0\\_PER](#) to set the THS work period.
- Step 6** Write 0x1 to the bit2 of [THS0\\_FILTER](#) to enable the temperature convert filter.
- Step 7** Write 0x1 to the bit [1:0] of [THS0\\_FILTER](#) to select the filter type.
- Step 8** Read THS eFuse value from SID, and then write the eFuse value to [TSENSOR4\\_CDATA](#) to calibrate THS.
- Step 9** Write 0x1 to the bit [0] of [THS0\\_DATA\\_INTC](#) to enable the interrupt of THS.
- Step 10** Set GIC interface based on IRQ 71.
- Step 11** Put the interrupt handler address into the interrupt vector table.
- Step 12** Write 0x1 to the bit [0] of [THS0\\_EN](#) to enable THS.
- Step 13** Read the bit [0] of [THS0\\_DATA\\_INTS](#). If it is 1, the temperature conversion is complete.
- Step 14** Read the bit [11:0] of [TSENSOR4\\_DATA](#), and calculate the THS temperature based on section 2.14.3.4 THS Temperature Conversion Formula

#### 2.14.5 Register List

THS module includes two groups of registers:

| Module Name | Base Address |
|-------------|--------------|
| THS0        | 0x0200_A000  |
| THS1        | 0x0200_9400  |

### 2.14.5.1 THS0 Register list

| Module Name | Base Address |
|-------------|--------------|
| THS0        | 0x0200_A000  |

| Register Name              | Offset | Description                                  |
|----------------------------|--------|----------------------------------------------|
| THS0_CTRL                  | 0x0000 | THS0 Control Register                        |
| THS0_EN                    | 0x0004 | THS0 Enable Register                         |
| THS0_PER                   | 0x0008 | THS0 Period Control Register                 |
| THS0_DATA_INTC             | 0x0010 | THS0 Data Interrupt Control Register         |
| THS0_SHUT_INTC             | 0x0014 | THS0 Shut Interrupt Control Register         |
| THS0_ALARM_INTC            | 0x0018 | THS0 Alarm Interrupt Control Register        |
| THS0_DATA_INTS             | 0x0020 | THS0 Data Interrupt Status Register          |
| THS0_SHUT_INTS             | 0x0024 | THS0 Shut Interrupt Status Register          |
| THS0_ALARMO_INTS           | 0x0028 | THS0 Alarm off Interrupt Status Register     |
| THS0_ALARM_INTS            | 0x002C | THS0 Alarm Interrupt Status Register         |
| THS0_FILTER                | 0x0030 | THS0 Median Filter Control Register          |
| TSENSOR4_ALARM_CTRL        | 0x0040 | TSENSOR4 Alarm threshold Control Register    |
| TSENSR04_SHUTDOWN_C<br>TRL | 0x0080 | TSENSR04 Shutdown threshold Control Register |
| TSENSOR4_CDATA             | 0x00A0 | TSENSOR4 Calibration Data                    |
| TSENSOR4_DATA              | 0x00C0 | TSENSOR4 Data Register                       |

### 2.14.5.2 THS1 Registers List

| Module Name | Base Address |
|-------------|--------------|
| THS1        | 0x0200_9400  |

| Register Name    | Offset | Description                              |
|------------------|--------|------------------------------------------|
| THS1_CTRL        | 0x0000 | THS1 Control Register                    |
| THS1_EN          | 0x0004 | THS1 Enable Register                     |
| THS1_PER         | 0x0008 | THS1 Period Control Register             |
| THS1_DATA_INTC   | 0x0010 | THS1 Data Interrupt Control Register     |
| THS1_SHUT_INTC   | 0x0014 | THS1 Shut Interrupt Control Register     |
| THS1_ALARM_INTC  | 0x0018 | THS1 Alarm Interrupt Control Register    |
| THS1_DATA_INTS   | 0x0020 | THS1 Data Interrupt Status Register      |
| THS1_SHUT_INTS   | 0x0024 | THS1 Shut Interrupt Status Register      |
| THS1_ALARMO_INTS | 0x0028 | THS1 Alarm off Interrupt Status Register |
| THS1_ALARM_INTS  | 0x002C | THS1 Alarm Interrupt Status Register     |
| THS1_FILTER      | 0x0030 | THS1 Median Filter Control Register      |

| Register Name                   | Offset | Description                                             |
|---------------------------------|--------|---------------------------------------------------------|
| TSENSOR0_ALARM_CTRL             | 0x0040 | TSENSOR0 Alarm threshold Control Register               |
| TSENSOR1_ALARM_CTRL             | 0x0044 | TSENSOR1 Alarm threshold Control Register               |
| TSENSOR2_ALARM_CTRL             | 0x0048 | TSENSOR2 Alarm threshold Control Register               |
| TSENSOR0&TSENSOR1_SHUTDOWN_CTRL | 0x0080 | TSENSOR0 & TSENSOR1 Shutdown threshold Control Register |
| TSENSOR2_SHUTDOWN_CTRL          | 0x0084 | TSENSOR2 Shutdown threshold Control Register            |
| TSENSOR0&TSENSOR1_CALIBRATION   | 0x00A0 | TSENSOR0 & TSENSOR1 Calibration Data                    |
| TSENSOR2_CALIBRATION            | 0x00A4 | TSENSOR2 Calibration Data                               |
| TSENSOR0_DATA                   | 0x00C0 | TSENSOR0 Data Register                                  |
| TSENSOR1_DATA                   | 0x00C4 | TSENSOR1 Data Register                                  |
| TSENSOR2_DATA                   | 0x00C8 | TSENSOR2 Data Register                                  |

## 2.14.6 THS0 Register Description

### 2.14.6.1 0x0000 THS0 Control Register (Default Value: 0x01DF\_002F)

| Offset: 0x0000 |            |             | Register Name: THS0_CTRL                                                  |
|----------------|------------|-------------|---------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                               |
| 31:16          | R/W        | 0x1DF       | TACQ<br>ADC Acquire Time<br>CLK_IN/ (n + 1)<br>The default value is 2 us. |
| 15:0           | R          | 0x2F        | Reserved                                                                  |

### 2.14.6.2 0x0004 THS0 Enable Register (Default Value: 0x0000\_0000)

| Offset: 0x0004 |            |             | Register Name: THS0_EN                                                          |
|----------------|------------|-------------|---------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                     |
| 31:1           | /          | /           | /                                                                               |
| 0              | R/W        | 0x0         | TSENSOR40_EN<br>Enable temperature measurement sensor<br>0: Disable<br>1:Enable |

### 2.14.6.3 0x0008 THS0 Period Control Register (Default Value: 0x0003\_A000)

| Offset: 0x0008 |            |             | Register Name: THS0_PER |
|----------------|------------|-------------|-------------------------|
| Bit            | Read/Write | Default/Hex | Description             |

| Offset: 0x0008 |            |             | Register Name: THS0_PER                                                                             |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                         |
| 31:12          | R/W        | 0x3A        | THERMAL_PER<br>Temperature measurement period<br>4096*(n + 1)/CLK_IN<br>The default value is 10 ms. |
| 11:0           | /          | /           | /                                                                                                   |

#### 2.14.6.4 0x0010 THS0 Data Interrupt Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0010 |            |             | Register Name: THS0_DATA_INTC                                                                      |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                        |
| 31:1           | /          | /           | /                                                                                                  |
| 0              | R/W        | 0x0         | TSENSOR4_DATA_IRQ_EN<br>Selects Temperature measurement data of TSENSOR4<br>0: Disable<br>1:Enable |

#### 2.14.6.5 0x0014 THS0 Shut Interrupt Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0014 |            |             | Register Name: THS0_SHUT_INTC                                                    |
|----------------|------------|-------------|----------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                      |
| 31:1           | /          | /           | /                                                                                |
| 0              | R/W        | 0x0         | SHUT_INT_EN<br>Selects shutdown interrupt for TSENSOR4<br>0: Disable<br>1:Enable |

#### 2.14.6.6 0x0018 THS0 Alarm Interrupt Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0018 |            |             | Register Name: THS0_ALARM_INTC                                                 |
|----------------|------------|-------------|--------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                    |
| 31:1           | /          | /           | /                                                                              |
| 0              | R/W        | 0x0         | ALARM_INT_EN<br>Selects alarm interrupt for TSENSOR4<br>0: Disable<br>1:Enable |

#### 2.14.6.7 0x0020 THS0 Data Interrupt Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0020 |            |             | Register Name: THS0_DATA_INTS                                                                     |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                       |
| 31:1           | /          | /           | /                                                                                                 |
| 0              | R/W1C      | 0x0         | TSENSOR4_DATA_IRQ_STS<br>Data interrupt status for TSENSOR4<br>Write '1' to clear this interrupt. |

#### 2.14.6.8 0x0024 THS0 Shut Interrupt Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0024 |            |             | Register Name: THS0_SHUT_INTS                                                                |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                  |
| 31:1           | /          | /           | /                                                                                            |
| 0              | R/W1C      | 0x0         | SHUT_INT_STS<br>Shutdown Interrupt Status for TSENSOR4<br>Write '1' to clear this interrupt. |

#### 2.14.6.9 0x0028 THS0 Alarm off Interrupt Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0028 |            |             | Register Name: THS0_ALARMO_INTS                                                                 |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                     |
| 31:1           | /          | /           | /                                                                                               |
| 0              | R/W1C      | 0x0         | ALARM_OFF_STS<br>Alarm Interrupt Off Pending for TSENSOR4<br>Write '1' to clear this interrupt. |

#### 2.14.6.10 0x002C THS0 Alarm Interrupt Status Register (Default Value: 0x0000\_0000)

| Offset: 0x002C |            |             | Register Name: THS0_ALARM_INTS                                                              |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                 |
| 31:1           | /          | /           | /                                                                                           |
| 0              | R/W1C      | 0x0         | ALARM_INT_STS<br>Alarm Interrupt Pending for TSENSOR4<br>Write '1' to clear this interrupt. |

#### 2.14.6.11 0x0030 THS0 Median Filter Control Register (Default Value: 0x0000\_0001)

| Offset: 0x0030 |            |             | Register Name: THS0_FILTER |
|----------------|------------|-------------|----------------------------|
| Bit            | Read/Write | Default/Hex | Description                |

| Offset: 0x0030 |            |             | Register Name: THS0_FILTER                                              |
|----------------|------------|-------------|-------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                             |
| 31:3           | /          | /           | /                                                                       |
| 2              | R/W        | 0x0         | FILTER_EN<br>Filter Enable<br>0: Disable<br>1: Enable                   |
| 1:0            | R/W        | 0x1         | FILTER_TYPE<br>Average Filter Type<br>00: 2<br>01: 4<br>10: 8<br>11: 16 |

#### 2.14.6.12 0x0040 THS0 Alarm Threshold Control Register (Default Value: 0x05A0\_0684)

| Offset: 0x0040 |            |             | Register Name: THS0_ALARM_CTRL                                      |
|----------------|------------|-------------|---------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                         |
| 31:28          | /          | /           | /                                                                   |
| 27:16          | R/W        | 0x5A0       | ALARM_T_HOT<br>TSENSOR4 Alarm Threshold for Hot Temperature         |
| 15:12          | /          | /           | /                                                                   |
| 11:0           | R/W        | 0x684       | ALARM_T_HYST<br>TSENSOR4 Alarm Threshold for Hysteresis temperature |

#### 2.14.6.13 0x0080 TSENSOR4 Shutdown Threshold Control Register (Default Value: 0x04E9\_04E9)

| Offset: 0x0080 |            |             | Register Name: TSENSOR4_SHUTDOWN_CTRL                         |
|----------------|------------|-------------|---------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                   |
| 31:12          | /          | /           | /                                                             |
| 11:0           | R/W        | 0x4E9       | SHUT_T_HOT<br>TSENSOR4 Shutdown Threshold for Hot Temperature |

#### 2.14.6.14 0x00A0 TSENSOR4 Calibration Data (Default Value: 0x0800\_0800)

| Offset: 0x00A0 |            |             | Register Name: TSENSOR4_CDATA |
|----------------|------------|-------------|-------------------------------|
| Bit            | Read/Write | Default/Hex | Description                   |
| 31:12          | /          | /           | /                             |
| 11:0           | R/W        | 0x800       | TSENSOR4_CDATA                |

| Offset: 0x00A0 |            |             | Register Name: TSENSOR4_CDATA |
|----------------|------------|-------------|-------------------------------|
| Bit            | Read/Write | Default/Hex | Description                   |
|                |            |             | TSENSOR4 Calibration Data     |

#### 2.14.6.15 0x00C0 TSENSOR4 Data Register (Default Value: 0x0000\_0000)

| Offset: 0x00C0 |            |             | Register Name: TSENSOR4_DATA                              |
|----------------|------------|-------------|-----------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                               |
| 31:12          | /          | /           | /                                                         |
| 11:0           | R          | 0x0         | TSENSOR4_DATA<br>Temperature measurement data of TSENSOR4 |

#### 2.14.7 THS1 Register Description

##### 2.14.7.1 0x0000 THS1 Control Register (Default Value: 0x01DF\_002F)

| Offset: 0x0000 |            |             | Register Name: THS1_CTRL                                                  |
|----------------|------------|-------------|---------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                               |
| 31:16          | R/W        | 0x1DF       | TACQ<br>ADC Acquire Time<br>CLK_IN/ (n + 1)<br>The default value is 2 us. |
| 15:0           | R          | 0x2F        | Reserved                                                                  |

##### 2.14.7.2 0x0004 THS1 Enable Register (Default Value: 0x0000\_0000)

| Offset: 0x0004 |            |             | Register Name: THS1_EN                                                          |
|----------------|------------|-------------|---------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                     |
| 31:3           | /          | /           | /                                                                               |
| 2              | R/W        | 0x0         | TSENSOR2_EN<br>Enable Temperature Measurement Sensor2<br>0: Disable<br>1:Enable |
| 1              | R/W        | 0x0         | TSENSOR1_EN<br>Enable Temperature Measurement Sensor1<br>0: Disable<br>1:Enable |
| 0              | R/W        | 0x0         | TSENSOR0_EN<br>Enable Temperature Measurement Sensor0<br>0: Disable<br>1:Enable |

#### 2.14.7.3 0x0008 THS1 Period Control Register (Default Value: 0x0003\_A000)

| Offset: 0x0008 |            |             | Register Name: THS1_PER                                                                             |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                         |
| 31:12          | R/W        | 0x3A        | THERMAL_PER<br>Temperature Measurement Period<br>4096*(n + 1)/CLK_IN<br>The default value is 10 ms. |
| 11:0           | /          | /           | /                                                                                                   |

#### 2.14.7.4 0x0010 THS1 Data Interrupt Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0010 |            |             | Register Name: THS1_DATA_INTC                                                                      |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                        |
| 31:3           | /          | /           | /                                                                                                  |
| 2              | R/W        | 0x0         | TSENSOR2_DATA_IRQ_EN<br>Selects Temperature measurement data of TSENSOR2<br>0: Disable<br>1:Enable |
| 1              | R/W        | 0x0         | TSENSOR1_DATA_IRQ_EN<br>Selects Temperature measurement data of TSENSOR1<br>0: Disable<br>1:Enable |
| 0              | R/W        | 0x0         | TSENSOR0_DATA_IRQ_EN<br>Selects Temperature measurement data of TSENSOR0<br>0: Disable<br>1:Enable |

#### 2.14.7.5 0x0014 THS1 Shut Interrupt Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0014 |            |             | Register Name: THS1_SHUT_INTC                                                     |
|----------------|------------|-------------|-----------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                       |
| 31:3           | /          | /           | /                                                                                 |
| 2              | R/W        | 0x0         | SHUT_INT2_EN<br>Selects Shutdown Interrupt for TSENSOR2<br>0: Disable<br>1:Enable |
| 1              | R/W        | 0x0         | SHUT_INT1_EN<br>Selects Shutdown Interrupt for TSENSOR1                           |

| Offset: 0x0014 |            |             | Register Name: THS1_SHUT_INTC                                                     |
|----------------|------------|-------------|-----------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                       |
|                |            |             | 0: Disable<br>1:Enable                                                            |
| 0              | R/W        | 0x0         | SHUT_INT0_EN<br>Selects Shutdown Interrupt for TSENSOR0<br>0: Disable<br>1:Enable |

#### 2.14.7.6 0x0018 THS1 Alarm Interrupt Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0018 |            |             | Register Name: THS1_ALARM_INTC                                                  |
|----------------|------------|-------------|---------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                     |
| 31:3           | /          | /           | /                                                                               |
| 2              | R/W        | 0x0         | ALARM_INT2_EN<br>Selects Alarm Interrupt for TSENSOR2<br>0: Disable<br>1:Enable |
| 1              | R/W        | 0x0         | ALARM_INT1_EN<br>Selects Alarm Interrupt for TSENSOR1<br>0: Disable<br>1:Enable |
| 0              | R/W        | 0x0         | ALARM_INT0_EN<br>Selects Alarm Interrupt for TSENSOR0<br>0: Disable<br>1:Enable |

#### 2.14.7.7 0x0020 THS1 Data Interrupt Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0020 |            |             | Register Name: THS1_DATA_INTS                                                                     |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                       |
| 31:3           | /          | /           | /                                                                                                 |
| 2              | R/W1C      | 0x0         | TSENSOR2_DATA_IRQ_STS<br>Data Interrupt Status for TSENSOR2<br>Write '1' to clear this interrupt. |
| 1              | R/W1C      | 0x0         | TSENSOR1_DATA_IRQ_STS<br>Data Interrupt Status for TSENSOR1<br>Write '1' to clear this interrupt. |
| 0              | R/W1C      | 0x0         | TSENSOR0_DATA_IRQ_STS<br>Data Interrupt Status for TSENSOR0<br>Write '1' to clear this interrupt. |

#### 2.14.7.8 0x0024 THS1 Shut Interrupt Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0024 |            |             | Register Name: THS1_SHUT_INTS                                                                 |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                   |
| 31:3           | /          | /           | /                                                                                             |
| 2              | R/W1C      | 0x0         | SHUT_INT2_STS<br>Shutdown Interrupt Status for TSENSOR2<br>Write '1' to clear this interrupt. |
| 1              | R/W1C      | 0x0         | SHUT_INT1_STS<br>Shutdown Interrupt Status for TSENSOR1<br>Write '1' to clear this interrupt. |
| 0              | R/W1C      | 0x0         | SHUT_INT0_STS<br>Shutdown Interrupt Status for TSENSOR0<br>Write '1' to clear this interrupt. |

#### 2.14.7.9 0x0028 THS1 Alarm off Interrupt Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0028 |            |             | Register Name: THS1_ALARMO_INTS                                                                  |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                      |
| 31:3           | /          | /           | /                                                                                                |
| 2              | R/W1C      | 0x0         | ALARM_OFF2_STS<br>Alarm Interrupt Off Pending for TSENSOR2<br>Write '1' to clear this interrupt. |
| 1              | R/W1C      | 0x0         | ALARM_OFF1_STS<br>Alarm Interrupt Off Pending for TSENSOR1<br>Write '1' to clear this interrupt. |
| 0              | R/W1C      | 0x0         | ALARM_OFF0_STS<br>Alarm Interrupt Off Pending for TSENSOR0<br>Write '1' to clear this interrupt. |

#### 2.14.7.10 0x002C THS1 Alarm Interrupt Status Register (Default Value: 0x0000\_0000)

| Offset: 0x002C |            |             | Register Name: THS1_ALARM_INTS                                                               |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                  |
| 31:3           | /          | /           | /                                                                                            |
| 2              | R/W1C      | 0x0         | ALARM_INT2_STS<br>Alarm Interrupt Pending for TSENSOR2<br>Write '1' to clear this interrupt. |
| 1              | R/W1C      | 0x0         | ALARM_INT1_STS<br>Alarm Interrupt Pending for TSENSOR1<br>Write '1' to clear this interrupt. |
| 0              | R/W1C      | 0x0         | ALARM_INT0_STS                                                                               |

| Offset: 0x002C |            |             | Register Name: THS1_ALARM_INTS                                             |
|----------------|------------|-------------|----------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                |
|                |            |             | Alarm Interrupt Pending for TSENSOR0<br>Write '1' to clear this interrupt. |

#### 2.14.7.11 0x0030 THS1 Median Filter Control Register (Default Value: 0x0000\_0001)

| Offset: 0x0030 |            |             | Register Name: THS1_FILTER                                              |
|----------------|------------|-------------|-------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                             |
| 31:3           | /          | /           | /                                                                       |
| 2              | R/W        | 0x0         | FILTER_EN<br>Filter Enable<br>0: Disable<br>1: Enable                   |
| 1:0            | R/W        | 0x1         | FILTER_TYPE<br>Average Filter Type<br>00: 2<br>01: 4<br>10: 8<br>11: 16 |

#### 2.14.7.12 0x0040 TSENSOR0 Alarm Threshold Control Register (Default Value: 0x05A0\_0684)

| Offset: 0x0040 |            |             | Register Name: TSENSOR0_ALARM_CTRL                                   |
|----------------|------------|-------------|----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                          |
| 31:28          | /          | /           | /                                                                    |
| 27:16          | R/W        | 0x5A0       | ALARM0_T_HOT<br>TSENSOR0 Alarm Threshold for Hot Temperature         |
| 15:12          | /          | /           | /                                                                    |
| 11:0           | R/W        | 0x684       | ALARM0_T_HYST<br>TSENSOR0 Alarm Threshold for Hysteresis Temperature |

#### 2.14.7.13 0x0044 TSENSOR1 Alarm Threshold Control Register (Default Value: 0x05A0\_0684)

| Offset: 0x0044 |            |             | Register Name: TSENSOR1_ALARM_CTRL                           |
|----------------|------------|-------------|--------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                  |
| 31:28          | /          | /           | /                                                            |
| 27:16          | R/W        | 0x5A0       | ALARM1_T_HOT<br>TSENSOR1 Alarm Threshold for Hot Temperature |
| 15:12          | /          | /           | /                                                            |

| Offset: 0x0044 |            |             | Register Name: TSENSOR1_ALARM_CTRL                                   |
|----------------|------------|-------------|----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                          |
| 11:0           | R/W        | 0x684       | ALARM1_T_HYST<br>TSENSOR1 Alarm Threshold for Hysteresis Temperature |

#### 2.14.7.14 0x0048 TSENSOR2 Alarm Threshold Control Register (Default Value: 0x05A0\_0684)

| Offset: 0x0048 |            |             | Register Name: TSENSOR2_ALARM_CTRL                                   |
|----------------|------------|-------------|----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                          |
| 31:28          | /          | /           | /                                                                    |
| 27:16          | R/W        | 0x5A0       | ALARM2_T_HOT<br>TSENSOR2 Alarm Threshold for Hot Temperature         |
| 15:12          | /          | /           | /                                                                    |
| 11:0           | R/W        | 0x684       | ALARM2_T_HYST<br>TSENSOR2 Alarm Threshold for Hysteresis Temperature |

#### 2.14.7.15 0x0080 TSENSOR0 & TSENSOR1 Shutdown Threshold Control Register (Default Value: 0x04E9\_04E9)

| Offset: 0x0080 |            |             | Register Name:<br>TSENSOR0&TSENSOR1_SHUTDOWN_CTRL              |
|----------------|------------|-------------|----------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                    |
| 31:28          | /          | /           | /                                                              |
| 27:16          | R/W        | 0x4E9       | SHUT1_T_HOT<br>TSENSOR1 Shutdown Threshold for Hot Temperature |
| 15:12          | /          | /           | /                                                              |
| 11:0           | R/W        | 0x4E9       | SHUT0_T_HOT<br>TSENSOR0 Shutdown Threshold for Hot Temperature |

#### 2.14.7.16 0x0084 TSENSOR2 Shutdown Threshold Control Register (Default Value: 0x0000\_04E9)

| Offset: 0x0084 |            |             | Register Name: TSENSOR2_SHUTDOWN_CTRL                          |
|----------------|------------|-------------|----------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                    |
| 31:12          | /          | /           | /                                                              |
| 11:0           | R/W        | 0x4E9       | SHUT2_T_HOT<br>TSENSOR2 Shutdown Threshold for Hot Temperature |

#### 2.14.7.17 0x00A0 TSENSOR0 & TSENSOR1 Calibration Data (Default Value: 0x0800\_0800)

| Offset: 0x00A0 |            |             | Register Name: TSENSOR0&TSENSOR1_CDATA      |
|----------------|------------|-------------|---------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                 |
| 31:28          | /          | /           | /                                           |
| 27:16          | R/W        | 0x800       | TSENSOR1_CDATA<br>TSENSOR1 Calibration Data |
| 15:12          | /          | /           | /                                           |
| 11:0           | R/W        | 0x800       | TSENSOR0_CDATA<br>TSENSOR0 Calibration Data |

#### 2.14.7.18 0x00A4 TSENSOR2 Calibration Data (Default Value: 0x0000\_0800)

| Offset: 0x00A4 |            |             | Register Name: TSENSOR2_CDATA               |
|----------------|------------|-------------|---------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                 |
| 31:12          | /          | /           | /                                           |
| 11:0           | R/W        | 0x800       | TSENSOR2_CDATA<br>TSENSOR2 Calibration Data |

#### 2.14.7.19 0x00C0 TSENSOR0 Data Register (Default Value: 0x0000\_0000)

| Offset: 0x00C0 |            |             | Register Name: TSENSOR0_DATA                              |
|----------------|------------|-------------|-----------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                               |
| 31:12          | /          | /           | /                                                         |
| 11:0           | R          | 0x0         | TSENSOR0_DATA<br>Temperature Measurement Data of TSENSOR0 |

#### 2.14.7.20 0x00C4 TSENSOR1 Data Register (Default Value: 0x0000\_0000)

| Offset: 0x00C4 |            |             | Register Name: TSENSOR1_DATA                              |
|----------------|------------|-------------|-----------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                               |
| 31:12          | /          | /           | /                                                         |
| 11:0           | R          | 0x0         | TSENSOR1_DATA<br>Temperature Measurement Data of TSENSOR1 |

#### 2.14.7.21 0x00C8 TSENSOR2 Data Register (Default Value: 0x0000\_0000)

| Offset: 0x00C8 |            |             | Register Name: TSENSOR2_DATA |
|----------------|------------|-------------|------------------------------|
| Bit            | Read/Write | Default/Hex | Description                  |
| 31:12          | /          | /           | /                            |

| Offset: 0x00C8 |            |             | Register Name: TSENSOR2_DATA                              |
|----------------|------------|-------------|-----------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                               |
| 11:0           | R          | 0x0         | TSENSOR2_DATA<br>Temperature Measurement Data of TSENSOR2 |



## 2.15 Timer

### 2.15.1 Overview

The Timer module implements the timing and counting functions, which includes CPUX\_TIMER, CPUS\_TIMER, and MCU\_TIMER. There are 6 timers in TIMER, 3 timers in CPUS\_TIMER, and 6 timers in MCU\_TIMER.

The Timer module has the following features:

- The AHB port is used to configure the timer register
- Configurable count clock: PRCM/CCU can be switched to 32 kHz, 24 MHz, 16 MHz, and 200 MHz
- Programmable 56-bit down timer
- Supports two timing modes: periodic mode and single counting mode
- Generates an interrupt when the count is decreased to 0

### 2.15.2 Block Diagram

The timer is a 56-bit down counter. The counter value is decremented by 1 on each rising edge of the timer clock.

The following figure shows the block diagram for the timer.

Figure 2-46 Block Diagram for the Timer



timer0 is used for illustration here. Block diagrams for other timers are the same.

## 2.15.3 Functional Descriptions

### 2.15.3.1 Typical Application

The following figure shows the typical application of the Timer module.

Figure 2-47 Timer Typical Application



The Timer is mounted at the AHB bus. The system configures and controls the Timer via the AHB bus.

### 2.15.3.2 Formula for Calculating the Timer Time

The following formula describes the relationship among timer parameters.

$$T = \frac{\{ \text{TIMER\_IVH}, \text{TIMER\_IVL} \} - \{ \text{TIMER\_CVH}, \text{TIMER\_CVL} \}}{f_{\text{clk\_timer}}}$$

Where,

TIMER\_IVH=the higher 24 bits of the interval value, which could be configured by the lower 24 bits of the [TIMER\\_IVH\\_REG](#) register;

TIMER\_IVL=the lower 32 bits of the interval value, which could be configured by the [TIMER\\_IVL\\_REG](#) register;

TIMER\_CVH=the higher 24 bits of the current value, which could be configured by the lower 24 bits of the [TIMER\\_CVH\\_REG](#) register;

TIMER\_CVL=the lower 32 bits of the current value, which could be configured by the [TIMER\\_CVL\\_REG](#) register;

fclk\_timer=the frequency of the timer clock source;

{TIMER\_IVH, TIMER\_IVL}=56-bit interval value of the timer;

{TIMER\_CVH, TIMER\_CVL}=56-bit current value of the timer.

### 2.15.3.3 Timing Modes

The timer has two timing modes: the single counting mode and the periodic mode. You can configure the timing mode via the bit[7] of [TIMER\\_CTRL\\_REG](#). The value 0 is for the period mode and value 1 is for the single counting mode.

- Single Counting Mode

In the single counting mode, the timer starts counting from the interval value and generates an interrupt after the counter decreases to 0, and then stops counting. It starts to count again only when the interval value is reloaded.

- Periodic Mode

In the periodic mode, the timer restarts another round of counting after generating the interrupt. It reloads data from the Timer Interval Value and then continues to count.

### 2.15.4 Programming Guidelines

#### 2.15.4.1 Initializing the Timer

Refer to the following steps to initialize the timer:

**Step 1** Configure the timer parameters including the clock source and timing mode by writing [TIMER\\_CTRL\\_REG](#). There is no sequence requirement of configuring these parameters.

**Step 2** Write the interval value.

- a) Write TIMER\_IVL bit of [TIMER\\_IVL\\_REG](#) register and TIMER\_IVH bit of [TIMER\\_IVH\\_REG](#) register to configure the interval value for the timer.
- b) Write bit [1] of [TIMER\\_CTRL\\_REG](#) to load the interval value to the timer. The value of the bit will be cleared automatically after the interval value is loaded.

**Step 3** Write bit [0] of [TIMER\\_CTRL\\_REG](#) to start the timer. Read TIMER\_CVL bit of [TIMER\\_CVL\\_REG](#) register and TIMER\_CVH bit of [TIMER\\_CVH\\_REG](#) register to get the current value of the timer.



#### NOTE

When performing read or write operations on the current register, operate [TIMER\\_CVL\\_REG](#) register before [TIMER\\_CVH\\_REG](#) register.

#### 2.15.4.2 Processing the Interrupt

Refer to the following steps to process the interrupt:

- Step 1** Enable interrupts for the timer: write the enable bit of the corresponding interrupt in [TIMER\\_IRQ\\_REG](#) for the timer. The timer will generate an interrupt once the count value reaches 0.
- Step 2** After the software program enters the interrupt process, write the pending bit of the corresponding interrupt in [TIMER\\_STA\\_REG](#) to clear the interrupt pending.
- Step 3** Resume the interrupt and continue to execute the interrupted process.

#### 2.15.5 Register List

| Module Name | Base Address | The value of N |
|-------------|--------------|----------------|
| CPUX_TIMER  | 0x0300 8000  | 0-5            |
| CPUS_TIMER  | 0x0709 0400  | 0-2            |
| MCU_TIMER   | 0x0712 3000  | 0-5            |

| Register Name  | Offset          | Description                              |
|----------------|-----------------|------------------------------------------|
| TIMER_IRQ_REG  | 0x0000          | Timer IRQ Enable Register                |
| TIMER_STA_REG  | 0x0004          | Timer Status Register                    |
| TIMER_SEC_REG  | 0x0008          | Timer Secure Register                    |
| TIMER_CTRL_REG | 0x0020+0x0020*N | Timer Control Register                   |
| TIMER_IVL_REG  | 0x0024+0x0020*N | Timer Interval Value bit[31:0] Register  |
| TIMER_CVL_REG  | 0x0028+0x0020*N | Timer Current Value [31:0]bit Register   |
| TIMER_IVH_REG  | 0x002C+0x0020*N | Timer Interval Value bit[55:32] Register |
| TIMER_CVH_REG  | 0x0030+0x0020*N | Timer Current Value [55:32]bit Register  |

#### 2.15.6 Register Description

##### 2.15.6.1 0x0000 Timer IRQ Enable Register (Default: 0x0000\_0000)

| Offset: 0x0000 |            |             | Register Name: TIMER_IRQ_REG                                |
|----------------|------------|-------------|-------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                 |
| 31:NUM         | /          | /           | /                                                           |
| NUM-1:0        | R/W        | 0x0         | Timer (0-NUM-1) Interrupt Enable<br>1: Enable<br>0: Disable |

#### 2.15.6.2 0x0004 Timer Status Register (Default: 0x0000\_0000)

| Offset: 0x0004 |            |             | Register Name: TIMER_STA_REG                        |
|----------------|------------|-------------|-----------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                         |
| 31:NUM         | /          | /           | /                                                   |
| NUM-1:0        | R/WC       | 0x0         | Timer (0-NUM-1) Status<br>1: Pending<br>0:No effect |

#### 2.15.6.3 0x0008 Timer Secure Register (Default: 0x0000\_003F)

| Offset: 0x0008 |            |             | Register Name: TIMER_SEC_REG                                 |
|----------------|------------|-------------|--------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                  |
| 31:NUM         | /          | /           | /                                                            |
| NUM-1:0        | R/W        | 0x3F        | Timer (0-NUM-1) Secure Control<br>1: Secure<br>0: Non-secure |

#### 2.15.6.4 0x0020+0x0020\*N(N=0-5) Timer Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0020+0x0020*N(N=0-5) |            |             | Register Name: TIMER_CTRL_REG                                                                                                                                                                                                 |
|--------------------------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                   |
| 31:8                           | /          | /           | /                                                                                                                                                                                                                             |
| 7                              | R/W        | 0x0         | TIMER_MODE<br>Timer Mode<br>0: Continuous mode. When interval value reached, the timer will restart another round of counting automatically.<br>1: Single mode. When interval value is reached, the timer will stop counting. |
| 6:2                            | /          | /           | /                                                                                                                                                                                                                             |
| 1                              | R/W        | 0x0         | TIMER_RELOAD.<br>Timer 0 Reload.<br>0: No effect<br>1: Reload timer 0 Interval value<br>After the bit is set, it can not be written again before it's cleared automatically.                                                  |
| 0                              | R/W        | 0x0         | TIMER_EN.<br>Timer 0 Enable.<br>0: Stop/Pause<br>1: Start<br>By setting the bit to 1, the timer will be started. It                                                                                                           |

| Offset: 0x0020+0x0020*N(N=0-5) |            |             | Register Name: TIMER_CTRL_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|--------------------------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                                |            |             | <p> reloads the interval value register and then counts from the interval value to 0.</p> <p> By setting the bit to 0 before the timer counts to 0, the timer will be paused. The bit will be locked to 0 for at least 2 cycles. Within the 2 cycles, you cannot set the bit to 1 to restart the timer.</p> <p> The timer supports updating the interval value in the pause state. To start to down-count from the updated interval value, set both the reload bit and enable bit to 1.</p> <p> Additionally, in the single counting mode, after the count value reaches 0, the system will automatically change the bit to 0 to stop the timer.</p> |

#### 2.15.6.5 0x0024+0x0020\*N(N=0-5) Timer Low Interval Value Register (Default: 0x0000\_0000)

| Offset: 0x0024+0x0020*N(N=0-5) |            |             | Register Name: TIMER_IVL_REG                                    |
|--------------------------------|------------|-------------|-----------------------------------------------------------------|
| Bit                            | Read/Write | Default/Hex | Description                                                     |
| 31:0                           | R/W        | 0x0         | <p>TIMER_IVL</p> <p>Timer Interval Value bit[31:0] Register</p> |

#### 2.15.6.6 0x0028+0x0020\*N(N=0-5) Timer Low Current Value Register (Default: 0x0000\_0000)



- The current value register is a 56-bit register. When read or write the current value, the TIMER\_CVL should be read or write first.
- Enable the TIMER\_EN.bit (bit [0]) of the [TIMER\\_CTRL\\_REG](#) register and set the bus clock frequency of the Timer to be twice the function clock frequency before reading the current value register.

| Offset: 0x0028+0x0020*N(N=0-5) |            |             | Register Name: TIMER_CVL_REG                                   |
|--------------------------------|------------|-------------|----------------------------------------------------------------|
| Bit                            | Read/Write | Default/Hex | Description                                                    |
| 31:0                           | R/W        | 0x0         | <p>TIMER_CVL</p> <p>Timer Current Value bit[31:0] Register</p> |

#### 2.15.6.7 0x002C+0x0020\*N(N=0-5) Timer High Interval Value Register (Default: 0x0000\_0000)

| Offset: 0x002C+0x0020*N(N=0-5) | Register Name: TIMER_IVH_REG |
|--------------------------------|------------------------------|
|--------------------------------|------------------------------|

| Bit   | Read/Write | Default/Hex | Description                                           |
|-------|------------|-------------|-------------------------------------------------------|
| 31:24 | /          | /           | /                                                     |
| 23:0  | R/W        | 0x0         | TIMER_IVH<br>Timer Interval Value bit[55:32] Register |

#### 2.15.6.8 0x0030+0x0020\*N(N=0-5) Timer High Current Value Register (Default: 0x0000\_0000)



Enable the TIMER\_EN.bit (bit [0]) of the [TIMER\\_CTRL\\_REG](#) register and set the bus clock frequency of the Timer to be twice the function clock frequency before reading the current value register.

| Offset: 0x0030+0x0020*N(N=0-5) |            |             | Register Name: TIMER_CVH_REG                         |
|--------------------------------|------------|-------------|------------------------------------------------------|
| Bit                            | Read/Write | Default/Hex | Description                                          |
| 31:24                          | /          | /           | /                                                    |
| 23:0                           | R/W        | 0x0         | TIMER_CVH<br>Timer Current Value bit[55:32] Register |

## 2.16 Watchdog Timer (WDT)

### 2.16.1 Overview

Watchdog is used to transmit a reset signal to reset the entire system after an exception occurs in the system. It has the following features:

- Three watchdog timers: CPUX\_WDT in CPUX domain, CPUS\_WDT and RISCV\_WDT in CPUS domain
- 12 initial values to configure
- Generation of timeout interrupts
- Generation of reset signal
- Watchdog restart the timing

### 2.16.2 Block Diagram

The following figure shows the functional block diagram of the watchdog module.

Figure 2-48 Watchdog Block Diagram



### 2.16.3 Functional Descriptions

#### 2.16.3.1 Clock Sources

The clock source of the watchdog is either LOSC (32 kHz) or HOSC/750 (24 MHz/750). Configure the bit [8] of the [WDT\\_CFG\\_REG](#) to select a clock source.

### 2.16.3.2 Typical Application

Figure 2-49 Watchdog Application Diagram



Watchdog configures register by APB bus.

The system configures the time of watchdog, if the system has no timing for restart watchdog (such as bus hang dead), then watchdog sends out watchdog reset external signal to reset system; meanwhile watchdog outputs signal to RESET pad to reset PMIC.

### 2.16.3.3 Operating Modes

The watchdog is a 32-bit down counter, the counter value is decreased by 1 on each rising edge of the count clock. The watchdog has two operating modes.

- Interrupt mode

The bit [1:0] of the [WDT\\_CFG\\_REG](#) is set to 0x2, when the counter value reaches 0 and the bit [0] of the [WDT\\_IRQ\\_EN\\_REG](#) is written to 1, the watchdog generates an interrupt, the watchdog enters into interrupt mode.

- Reset mode

The bit [1:0] of the [WDT\\_CFG\\_REG](#) is set to 0x1, when the counter value reaches 0, the watchdog generates a reset signal to reset the entire system.

## 2.16.4 Programming Guidelines

### 2.16.4.1 Initializing the Watchdog

Follow the steps below to initialize the watchdog:

**Step 1** Configure the bit [1:0] of the [WDT\\_CFG\\_REG](#) to configure the generation of the interrupts or the output of reset signal.

**Step 2** Configure the bit [7:4] of the [WDT\\_MODE\\_REG](#) to configure the initial count value.

**Step 3** Write the bit [0] of the [WDT\\_MODE\\_REG](#) to 1 to enable the watchdog.

#### 2.16.4.2 Processing the Interrupt

Follow the steps below to process the interrupt:

**Step 1** Write the bit [0] of the [WDT\\_IRQ\\_EN\\_REG](#) to 1 to enable the interrupt.

**Step 2** After enter the interrupt process, write the bit [0] of the [WDT\\_IRQ\\_STAT](#) to 1 to clear the interrupt pending, and execute the process of waiting for the interrupt.

**Step 3** Resume the interrupt and continue to execute the interrupted process.

#### 2.16.4.3 Resetting the Watchdog

In the following instance making configurations for WDT: configure clock source as HOSC/750, configure Interval Value as 1s and configure Watchdog Configuration as to whole system. This instance indicates that reset system after 1s.

```
writel(0x16AA_0001, WDT_CFG_REG); //To whole system  
writel(0x16AA_0010, WDT_MODE_REG); //Interval Value set 1s  
writel(readl(WDT_MODE_REG) |(1<<0)|(0x16AA<<16), WDT_MODE_REG); //Enable WDT
```

#### 2.16.4.4 Restarting the Watchdog

In the following instance making configurations for WDT: configure clock source as HOSC/750, configure Interval Value as 1s and configure Watchdog Configuration as to whole system. In the following instance, if the time of other codes is larger than 1s, watchdog will reset the whole system. If the sentence of restart watchdog is implemented inside 1s, watchdog will be restarted.

```
write(0x16AA_0001, WDT_CFG_REG); //To whole system  
write(0x16AA_0010, WDT_MODE_REG); //Interval Value set 1s  
writel(readl(WDT_MODE_REG) |(1<<0)|(0x16AA<<16), WDT_MODE_REG); //Enable WDT  
----other codes---  
writel(readl(WDT_CTRL_REG) |(0xA57<<1) | (1<<0), WDT_CTRL_REG); //Write 0xA57 at Key Field and Restart WDT
```

### 2.16.5 Register List

| Module Name | Base Address |
|-------------|--------------|
| CPUX_WDT    | 0x0205 0000  |
| CPUS_WDT    | 0x0702 0400  |
| RISCV_WDT   | 0x0713 2000  |

| Register Name  | Offset | Description                       |
|----------------|--------|-----------------------------------|
| WDT_IRQ_EN_REG | 0x0000 | WDT IRQ Enable Register           |
| WDT_IRQ_STAT   | 0x0004 | WDT Status Register               |
| WDT_SRST_REG   | 0x0008 | WDT Software Reset Register       |
| WDT_CTRL_REG   | 0x000C | WDT Control Register              |
| WDT_CFG_REG    | 0x0010 | WDT Configuration Register        |
| WDT_MODE_REG   | 0x0014 | WDT Mode Register                 |
| WDT_OCFG_REG   | 0x0018 | WDT Output Configuration Register |

## 2.16.6 Register Description

### 2.16.6.1 0x0000 WDT IRQ Enable Register (Default: 0x0000\_0000)

| Offset: 0x0000 |            |             | Register Name: WDT_IRQ_EN_REG |
|----------------|------------|-------------|-------------------------------|
| Bit            | Read/Write | Default/Hex | Description                   |
| 31:1           | /          | /           | /                             |
| 0              | R/W        | 0x0         | WDT Interrupt Enable          |

### 2.16.6.2 0x0004 WDT Status Register (Default: 0x0000\_0000)

| Offset: 0x0004 |            |             | Register Name: WDT_IRQ_STAT                                                                                             |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                             |
| 31:1           | /          | /           | /                                                                                                                       |
| 0              | R/WAC      | 0x0         | WDT Status<br>WDT IRQ Pending.set 1 to the bit will clear it.<br>1:pending,WDT interval value is reached<br>0:No effect |

### 2.16.6.3 0x0008 WDT Software Reset Register Register (Default: 0x0000\_0000)

| Offset: 0x0008 |            |             | Register Name: WDT_SRST_REG                                                                                 |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                 |
| 31:16          | R          | 0x0         | KEY Field<br>This field should be filled with 0x16AA, and then the bit 0 can be written with the new value. |
| 15:1           | /          | /           | /                                                                                                           |
| 0              | R/W        | 0x0         | Soft Reset Enable<br>0: De-assert<br>1: Reset System                                                        |

| Offset: 0x0008 |            |             | Register Name: WDT_SRST_REG                                            |
|----------------|------------|-------------|------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                            |
|                |            |             | If this bit is used for system reset, the watchdog should be disabled. |

#### 2.16.6.4 0x000C WDT Control Register Register (Default: 0x0000\_0000)

| Offset: 0x000C |            |             | Register Name: WDT_CTRL_REG                                                                                               |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                               |
| 31:13          | /          | /           | /                                                                                                                         |
| 12:1           | W          | 0x0         | Watchdog Key Field<br>Should be written at value 0xA57. Writing any other value in this field aborts the write operation. |
| 0              | R/W1S      | 0x0         | Watchdog Restart<br>0: No effect<br>1: Restart the Watchdog 0                                                             |

#### 2.16.6.5 0x0010 WDT Configuration Register Register (Default: 0x0000\_0001)

| Offset: 0x0010 |            |             | Register Name: WDT_CFG_REG                                                                                                 |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                |
| 31:16          | W          | 0x0         | KEY_FIELD.<br>Key Field. This field should be filled with 0x16AA, and then the bit 15:0 can be written with the new value. |
| 15:9           | /          | /           | /                                                                                                                          |
| 8              | R/W        | 0x0         | WDT Clock select<br>1: LOSC (32 kHz)<br>0: HOSC / 750 (24MHz/750)                                                          |
| 7:2            | /          | /           | /                                                                                                                          |
| 1:0            | R/W        | 0x1         | WDT Configuration<br>00: /<br>01: to whole system<br>10: only interrupt<br>11: /                                           |

#### 2.16.6.6 0x0014 WDT Mode Register Register (Default: 0x0000\_0000)

| Offset: 0x0014 |            |             | Register Name: WDT_MODE_REG |
|----------------|------------|-------------|-----------------------------|
| Bit            | Read/Write | Default/Hex | Description                 |

| Offset: 0x0014 |            |             | Register Name: WDT_MODE_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 31:16          | W          | 0x0         | KEY_FIELD<br>Key Field. This field should be filled with 0x16AA, and then the bit 15:0 can be written with the new value.                                                                                                                                                                                                                                                                                                                                                               |
| 15:8           | /          | //          | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 7:4            | R/W        | 0x0         | WDT Interval Value.<br>Watchdog clock source is HOSC / 750. If the clock source is turned off, WDT will not work.<br>0000: 16k cycles (0.5s)<br>0001: 32k cycles (1s)<br>0010: 64k cycles (2s)<br>0011: 96k cycles (3s)<br>0100: 128k cycles (4s)<br>0101: 160K cycles (5s)<br>0110: 192k cycles (6s)<br>0111: 256k cycles (8s)<br>1000: 320k cycles (10s)<br>1001: 384k cycles (12s)<br>1010: 448k cycles (14s)<br>1011: 512k cycles (16s)<br>1100: /<br>1101: /<br>1110: /<br>1111: / |
| 3:1            | /          | /           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 0              | R/W        | 0x0         | Watchdog Enable.<br>0: disable ;<br>1: enable                                                                                                                                                                                                                                                                                                                                                                                                                                           |

#### 2.16.6.7 0x0018 WDT Output Configuration Register Register (Default: 0x0000\_001F)

| Offset: 0x0018 |            |             | Register Name: WDT_OCFG_REG                                                                                                |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                |
| 31:16          | W          | 0x0         | KEY_FIELD.<br>Key Field. This field should be filled with 0x16AA, and then the bit 11:0 can be written with the new value. |
| 15:12          | /          | /           | /                                                                                                                          |
| 11:0           | R/W        | 0x1F        | WDT OUTPUT CONFIG<br>WDT Reset Valid Time Configuraion<br>T=1/32ms*(N+1)                                                   |

|                |            |             |                             |
|----------------|------------|-------------|-----------------------------|
| Offset: 0x0018 |            |             | Register Name: WDT_OCFG_REG |
| Bit            | Read/Write | Default/Hex | Description                 |
|                |            |             | Default 1ms                 |



# Contents

|       |                                        |     |
|-------|----------------------------------------|-----|
| 3     | Memory .....                           | 472 |
| 3.1   | RAW NAND Flash Controller (NDFC) ..... | 472 |
| 3.2   | SDRAM controller (DRAMC) .....         | 473 |
| 3.3   | SD/MMC Host Controller (SMHC) .....    | 474 |
| 3.3.1 | Overview .....                         | 474 |
| 3.3.2 | Block Diagram .....                    | 475 |
| 3.3.3 | Functional Description .....           | 476 |
| 3.3.4 | Programming Guidelines .....           | 488 |
| 3.3.5 | Register List .....                    | 495 |
| 3.3.6 | Register Description .....             | 497 |

# Figures

|                                                              |     |
|--------------------------------------------------------------|-----|
| Figure 3-1 SMHC Block Diagram .....                          | 475 |
| Figure 3-2 Command Token Format .....                        | 478 |
| Figure 3-3 Response Token Format .....                       | 478 |
| Figure 3-4 Data Packet Format for SDR .....                  | 479 |
| Figure 3-5 Data Packet Format for DDR .....                  | 480 |
| Figure 3-6 Data Packet Format for DDR in HS400 Mode .....    | 481 |
| Figure 3-7 Single-Block and Multi-Block Read Operation ..... | 482 |
| Figure 3-8 Single-Block and Multi-Block Read Operation ..... | 482 |
| Figure 3-9 IDMAC Descriptor Structure Diagram .....          | 485 |
| Figure 3-10 Initialization Process of Command Queue .....    | 494 |



# Tables

|                                           |     |
|-------------------------------------------|-----|
| Table 3-1 SMHC Sub-blocks .....           | 475 |
| Table 3-2 SMHC External Signals .....     | 476 |
| Table 3-3 SMHC0/1 Clock Sources .....     | 476 |
| Table 3-4 SMHC2 Clock Sources .....       | 476 |
| Table 3-5 Command and Data Location ..... | 482 |
| Table 3-6 DES0 Definition .....           | 486 |
| Table 3-7 DES1 Definition .....           | 486 |
| Table 3-8 DES2 Definition .....           | 487 |
| Table 3-9 DES3 Definition .....           | 487 |



## 3 Memory

### 3.1 RAW NAND Flash Controller (NDFC)

The NDFC is the NAND flash controller which supports all NAND flash memory available in the market. New types of flash can be supported by software re-configuration.

The NDFC has a built-in on-the-fly error correction code (ECC) feature with BCH algorithm to enhance the reliability. It can detect and correct up to 80 bits' error per 1024 bytes' data. With the on-chip BCH code ECC circuit, the CPU is freed for other tasks. You can disable the ECC feature by software.

The NDFC supports transferring data via the DMA or CPU memory-mapped IO. It provides automatic timing control for reading or writing external Flash and maintains the proper relativity for CLE, CE#, and ALE control signal lines. There are three modes for serial read access: the mode0 is for conventional serial access, the mode1 is for EDO type, and the mode2 is for extension EDO type. The NDFC can monitor the status of the R/B# signal line.

Block management and wear leveling management are implemented in software.

The NDFC has the following features:

- Supports all SLC/MLC flash and EF-NAND memory available in the market
- Supports configuring randomize seed by software
- Software configuration method for various systems and memory types
- Up to 8-bit data bus width
- Supports 2CE/2RB
- Supports 1024, 2048, 4096, 8192, 16384, and 32768 bytes' size per page
- Conventional and EDO serial access method for serial reading Flash
- 80 bits/1 KB on-the-fly BCH code ECC check and error correction
- Output bits' number information about the corrected errors
- ECC automatic disable function for all 0xff data
- NDFC status information is reported by its registers, and interrupt is supported
- One command FIFO
- Two 256x32-bit RAM for Pipeline Procession
- Supports SDR, ONFI DDR1.0, Toggle DDR1.0, ONFI DDR2.0, and Toggle DDR2.0 RAW NAND FLASH
- Maximum IO rate of 50 MHz in SDR mode, 100 MHz in DDR1.0 and 150MHz in DDR2.0 mode
- Self-debug for NDFC debug

## 3.2 SDRAM controller (DRAMC)

The DRAMC has the following features:

- 32-bit DDR3/DDR3L/DDR4/LPDDR3/LPDDR4/LPDDR4X interface
- Memory capacity up to 4GB
- Clock frequency up to 1066 MHz for DDR3, DDR3L, and LPDDR3
- Clock frequency up to 1200 MHz for DDR4, LPDDR4, and LPDDR4x
- 17 address lines and three bank address lines per channel
- Generate initialization and refresh sequences automatically
- Runtime-configurable parameters setting for application flexibility
- Programmable priority of transferring through multiple ports
- Supports random reading or writing
- Supports Dynamic Frequency Setting(DFS) via hardware
- Supports SSC



## 3.3 SD/MMC Host Controller (SMHC)

### 3.3.1 Overview

The SMHC controls the read/write operations on the secure digital (SD) cards, multimedia cards (MMC), and various extended devices that is based on the secure digital input/output (SDIO) protocol. The processor provides three SMHC interfaces for controlling the SD cards, MMCs, and SDIO devices.

The SMHC has the following features:

- Three SD/MMC host controller (SMHC) interfaces
  - SMHC0, compliant with the protocol Secure Digital Memory (SD3.0)
  - SMHC1, compliant with the protocol Secure Digital I/O (SDIO3.0)
  - SMHC2, compliant with the protocol Multimedia Card (eMMC5.1)
  - Supports one SD (Version1.0 to 3.0) or MMC (Version3.3 to 5.1)
- The SMHC0 and the SMHC1 support the following:
  - 1-bit or 4-bit data width
  - Maximum performance:
    - SDR mode 200 MHz@1.8 V IO pad
    - DDR mode 50 MHz@1.8 V IO pad
    - SDR mode 50 MHz@3.3 V IO pad
- The SMHC2 supports the following:
  - 1-bit, 4-bit, or 8-bit data width
  - Supports HS400 mode and HS200 mode
  - Maximum performance:
    - SDR mode 200MHz@1.8V IO pad
    - DDR mode 200MHz@1.8V IO pad
    - SDR mode 50MHz@3.3V IO pad
    - DDR mode 50MHz@3.3V IO pad
- Support block size of 1 to 65535 bytes
- Support hardware CRC generation and error detection
- Supports eMMC boot operation and alternative boot operation
- Supports command queue for eMMC V5.1 device
- Supports serial CMDQ mode for SMHC0/2
- Supports host pull-up control

- Supports Command Completion signals and interrupts to host processor, and Command Completion signal disable feature
- Programmable baud rate
- Descriptor-based internal DMA controller
- Internal time-multiplexing 1 KB FIFO for SMHC0/2 transmitting and receiving
- Internal time-multiplexing 4 KB FIFO for SMHC1 transmitting and receiving

### 3.3.2 Block Diagram

The following figure shows a block diagram of the SMHC.

**Figure 3-1 SMHC Block Diagram**



SMHC contains the following sub-blocks:

**Table 3-1 SMHC Sub-blocks**

| Sub-block | Description                                                                                                                                                                                 |
|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Register  | Used to configure the control signal for reading or writing the SD/SDIO/eMMC.                                                                                                               |
| DMAC      | The DMA controller that controls the data transfer between the memory and SMHC.                                                                                                             |
| FIFO      | A buffer for the data stream between the memory and the SMHC asynchronous clock domain.                                                                                                     |
| SYNC      | Synchronizes the signals from the AHB clock domain to the SMHC clock domain.                                                                                                                |
| CMD Path  | Sends commands to or receives commands from the SD/SDIO/eMMC.                                                                                                                               |
| Data Path | Consists of Data TX and Data RX sub-modules. The Data TX sends data blocks and the CRC codes to the SD/SDIO/eMMC. The Data RX receives data blocks and the CRC codes from the SD/SDIO/eMMC. |

### 3.3.3 Functional Description

#### 3.3.3.1 External Signals

The following table describes the external signals of SMHC.

**Table 3-2 SMHC External Signals**

| Signal Name  | Description                         | Type    |
|--------------|-------------------------------------|---------|
| <b>SMHC0</b> |                                     |         |
| SDC0-CMD     | Command Signal for SD Card          | I/O, OD |
| SDC0-CLK     | Clock for SD Card                   | O       |
| SDC0-D[3:0]  | DATA INPUT AND OUTPUT FOR SD CARD   | I/O     |
| <b>SMHC1</b> |                                     |         |
| SDC1-CMD     | Command Signal for SDIO WIFI        | I/O, OD |
| SDC1-CLK     | Clock for SDIO WIFI                 | O       |
| SDC1-D[3:0]  | Data Input and Output for SDIO WIFI | I/O     |
| <b>SMHC2</b> |                                     |         |
| SDC2-CMD     | Command Signal for eMMC             | I/O, OD |
| SDC2-CLK     | Clock for eMMC                      | O       |
| SDC2-D[8:0]  | Data Input and Output for eMMC      | I/O     |
| SDC2-RST     | Reset for eMMC                      | O       |
| SDC2-DS      | Clock input for eMMC                | I       |

#### 3.3.3.2 Clock Sources

The SMHC0/1/2 has 5 different clock sources. You can select one of them as the SMHC clock source. The following table describes the clock sources of the SMHC.

For clock setting, configurations, and gating information, refer to section 2.5 Clock Controller Unit (CCU).

**Table 3-3 SMHC0/1 Clock Sources**

| Clock Sources   | Description                                    | Module |
|-----------------|------------------------------------------------|--------|
| HOSC            | 24 MHz Crystal                                 | CCU    |
| PLL_PERI0(400M) | Peripheral Clock, the default value is 400 MHz |        |
| PLL_PERI0(300M) | Peripheral Clock, the default value is 300 MHz |        |
| PLL_PERI1(400M) | Peripheral Clock, the default value is 400 MHz |        |
| PLL_PERI1(300M) | Peripheral Clock, the default value is 300 MHz |        |

**Table 3-4 SMHC2 Clock Sources**

| Clock Sources   | Description                                    | Module |
|-----------------|------------------------------------------------|--------|
| HOSC            | 24 MHz Crystal                                 | CCU    |
| PLL_PERI0(800M) | Peripheral Clock, the default value is 800 MHz |        |
| PLL_PERI0(600M) | Peripheral Clock, the default value is 600 MHz |        |

| Clock Sources   | Description                                    | Module |
|-----------------|------------------------------------------------|--------|
| PLL_PERI1(800M) | Peripheral Clock, the default value is 800 MHz |        |
| PLL_PERI1(600M) | Peripheral Clock, the default value is 600 MHz |        |

### 3.3.3.3 Timing Diagram

Refer to the following relative specifications:

- Physical Layer Specification Ver3.00 Final
- SDIO Specification Ver2.00
- Multimedia Cards (MMC – version 4.2)
- JEDEC Standard – JESD84-44, Embedded Multimedia Card (eMMC) Card Product Standard
- JEDEC Standard – JESD84-B45, Embedded Multimedia Card (eMMC) Electrical Standard (4.5 Device)
- JEDEC Standard – JESD84-B50, Embedded Multimedia Card (eMMC) Electrical Standard (5.0)

### 3.3.3.4 Data Path

The SMHC and SD/SDIO/eMMC contains the following interface buses: CLK, CMD, and DATA 1/4. During one clock cycle, the SMHC can transmit one-bit command with one or two bits' data in 1-ch DATA mode, or four or eight bits' data in 4-ch DATA mode. The CMD is a bidirection channel for initializing the SD/SDIO/eMMC and transmitting commands. It can work in both the open-drain mode and push-pull mode. The DATA is also a bidirection channel. It works in the push-pull mode.

- Reading Data from the SD/SDIO/eMMC

The register configures the signals for the read operation, and synchronize the signals to the SMHC clock domain. Then the Data RX reads data from the SD/SDIO/eMMC via the CLK/CMD/DATA interface buses and writes the data in the FIFO. After that, the DMAC transfers the data from the FIFO to the memory.

- Writing Data to the SD/SDIO/eMMC

The register configures the signals for the write operation, and synchronize the signals to the SMHC clock domain. Then the DMAC reads data from the memory and writes the data to the FIFO. After that, the Data TX reads the data from the FIFO and writes the data to the SD/SDIO/eMMC via the CLK/CMD/DATA interface buses.

### 3.3.3.5 Package Format

Data transfer over the SD/eMMC bus is based on command and data bitstreams that are initiated by a start bit and terminated by a stop bit. There are three types of SD/eMMC packets: command token, response token, and data packet.

## Command Tokens

The command token starts an operation. A command is sent from the host to a device. It is transferred serially on the CMD line. Command tokens have the following coding scheme:

**Figure 3-2 Command Token Format**



Each command token has 48 bits, preceded by a start bit ('0') and succeeded by an end bit ('1'). To detect transmission errors, each token is protected by CRC bits.

## Response Tokens

After receiving a command, the card returns a 48-bit or 136-bit response based on the command type.

A response token is sent from the device to the host as an answer to a previously received command. It is transferred serially on the CMD line.

**Figure 3-3 Response Token Format**



## Data Packet

Data can be transferred from the device to the host or vice versa. Data are transferred via the data lines.

Figure 3-4 Data Packet Format for SDR

**1 Bit Bus (only DAT0 used)**

**8 Bits Bus (DAT7 - DAT0 used)**

**4 Bits Bus (DAT3 - DAT0 used)**


Figure 3-5 Data Packet Format for DDR

**4 Bits Bus DDR (DAT3 – DAT0 used)**

**8 Bits Bus DDR (DAT7 – DAT0 used)**




- Bytes data are not interleaved but CRCs are interleaved.
- Start and end bits are only valid on the rising edge ("X" indicates "undefined").

**Figure 3-6 Data Packet Format for DDR in HS400 Mode**

**8 Bits Bus DDR for HS400 Output (DAT7 – DAT0 used)**



- Bytes data are not interleaved but CRCs are interleaved.
- Start bits are valid when Data Strobe is High and Low.
- End bits are only valid when Data Strobe is High ("X" indicates "undefined").

## Data Transfer

Data transfers to or from the SD/eMMC card are done in blocks. Single and multiple block operations are widely used during data transfer.

The following figure shows the single-block and multi-block read operation.

**Figure 3-7 Single-Block and Multi-Block Read Operation**



The following figure shows the single-block and multi-block write operation.

**Figure 3-8 Single-Block and Multi-Block Write Operation**



### 3.3.3.6 Phase Offset of the Command and Data

To obtain the command phase or data phase in output timing, follow the steps below:

- Step 1** Configure the MODE\_SEL (bit [31]) and HS400\_NEW\_SAM\_EN (bit [0]) of [SMHC\\_NTSR](#) ([offset: 0x005C](#)) to choose the timing mode.
- Step 2** Configure the DAT\_DRV\_PH\_SEL (bit [17]) to select data drive phase offset and configure CMD\_DRV\_PH\_SEL (bit [16]) to select command drive phase offset in [SMHC\\_DRV\\_DL](#) ([offset: 0x0140](#)) to select data or command drive phase offset.

The following table shows the specific configuration of command and data location.

**Table 3-5 Command and Data Location**

| Timing Mode | DRV | Command Drive Phase offset | Data Drive Phase offset |
|-------------|-----|----------------------------|-------------------------|
|-------------|-----|----------------------------|-------------------------|

| Timing Mode                      | DRV | Command Drive Phase offset                 | Data Drive Phase offset                                                           |
|----------------------------------|-----|--------------------------------------------|-----------------------------------------------------------------------------------|
| SDR                              | 0   |                                            | <p>The Command updates at 90 degrees.</p> <p>The data update at 90 degrees.</p>   |
|                                  | 1   |                                            | <p>The Command updates at 180 degrees.</p> <p>The data update at 180 degrees.</p> |
| DDR4<br>(1x mode:<br>0x5c[31]=0) | 0   |                                            |                                                                                   |
|                                  | 1   |                                            |                                                                                   |
|                                  |     | <p>The Command updates at 180 degrees.</p> | <p>The data update at 0 or 180 degrees.</p>                                       |
| DDR4<br>(2x mode:<br>0x5c[31]=1) | 0   |                                            |                                                                                   |

| Timing Mode                          | DRV | Command Drive Phase offset          | Data Drive Phase offset              |
|--------------------------------------|-----|-------------------------------------|--------------------------------------|
| DDR8                                 | 1   | The Command updates at 45 degrees.  | The data update at 45 degrees.       |
|                                      |     |                                     |                                      |
|                                      | 0   | The Command updates at 45 degrees.  | The data update at 90 degrees.       |
|                                      |     |                                     |                                      |
|                                      | 1   | The Command updates at 45 degrees.  | The data update at 45 degrees.       |
|                                      |     |                                     |                                      |
| HS400<br>(1x mode:<br>0x5c[0]<br>=0) | 0   | The Command updates at 90 degrees.  | The data update at 90 degrees.       |
|                                      |     |                                     |                                      |
|                                      | 1   | The Command updates at 90 degrees.  | The data update at 90 degrees.       |
|                                      |     |                                     |                                      |
|                                      |     | The Command updates at 180 degrees. | The data update at 0 or 180 degrees. |

| Timing Mode                          | DRV | Command Drive Phase offset                                                                                                                                      | Data Drive Phase offset                                                            |
|--------------------------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|
| HS400<br>(2x mode:<br>0x5c[0]<br>=1) | 0   |  <p>The Command updates at 90 degrees.<br/>The data update at 45 degrees.</p>  |  |
|                                      | 1   |  <p>The Command updates at 180 degrees.<br/>The data update at 90 degrees.</p> |  |

### 3.3.3.7 Internal DMA Controller Description

The SMHC has an internal DMA controller (IDMAC) to transfer data between the host memory and SMHC port. With a descriptor, the IDMAC can efficiently move data from the source to destination by automatically loading the next DMA transfer arguments, which needs less CPU intervention. Before transferring data in the IDMAC, the Host CPU should construct a descriptor list, configure arguments of every DMA transfer, and then launch the descriptor and start the DMA.

The IDMAC has an interrupt controller. When enabled, it generates an interrupt to the Host CPU in situations such as data transmission is completed or some error is happened.

#### IDMAC Descriptor Structure

The IDMAC uses a descriptor with a chain structure, and each descriptor points to a unique buffer and the next descriptor.

The following figure shows the internal formats of a descriptor.

Figure 3-9 IDMAC Descriptor Structure Diagram



This figure illustrates the internal formats of a descriptor. The descriptor address must be aligned to the bus width used for 32-bit buses. Each descriptor contains 16 bytes of control and status information.

DES0 corresponds to the [31:0] bits, DES1 corresponds to the [63:32] bits, DES2 corresponds to the [95:64] bits, and DES3 corresponds the [127:96] bits in a descriptor.

The following table shows the bit definition of DES0.

**Table 3-6 DES0 Definition**

| Bits | Name                            | Description                                                                                                                                                                                                                                                                                                                                                                      |
|------|---------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31   | HOLD                            | DES_OWN_FLAG<br>When set, this bit indicates that the descriptor is owned by the IDMAC. When this bit is reset, it indicates that the descriptor is owned by the host. This bit is cleared when the transfer is over.<br><b>Note:</b> After this bit is cleared to 0, the Host CPU is able to read the transferred data or initiate next transfer by launching a new descriptor. |
| 30   | ERROR                           | ERR_FLAG<br>When some errors happen in transfer, this bit will be set to 1.                                                                                                                                                                                                                                                                                                      |
| 29:5 | /                               | /                                                                                                                                                                                                                                                                                                                                                                                |
| 4    | Chain Flag                      | CHAIN_MOD<br>When set to 1, this bit indicates that the second address in the descriptor is the next descriptor address. It must be set to 1.                                                                                                                                                                                                                                    |
| 3    | First DES Flag                  | FIRST_FLAG<br>When set to 1, this bit indicates that this descriptor contains the first buffer of data. It must be set to 1 in the first DES.                                                                                                                                                                                                                                    |
| 2    | Last DES Flag                   | LAST_FLAG<br>When set to 1, this bit indicates that the buffers this descriptor points to are the last data buffer.                                                                                                                                                                                                                                                              |
| 1    | Disable Interrupt on completion | CUR_TXRX_OVER_INT_DIS<br>When set to 1, this bit will prevent the setting of the TX/RX interrupt bit of the IDMAC status register for data that ends in the buffer the descriptor points to.                                                                                                                                                                                     |
| 0    | /                               | /                                                                                                                                                                                                                                                                                                                                                                                |

The following table shows the bit definition of DES1.

**Table 3-7 DES1 Definition**

| Bits  | Name        | Description                                                                                                                                                                         |
|-------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:13 | /           | /                                                                                                                                                                                   |
| 12:0  | Buffer size | BUFF_SIZE<br>The bits indicate the data buffer byte size, which must be a multiple of 4 bytes. If this field is 0, the DMA ignores this buffer and proceeds to the next descriptor. |

The following table shows the bit definition of DES2.

**Table 3-8 DES2 Definition**

| Bits | Name                   | Descriptor                                                                                       |
|------|------------------------|--------------------------------------------------------------------------------------------------|
| 31:0 | Buffer address pointer | BUFF_ADDR<br>The bits indicate the physical address of the data buffer.<br>It is a word address. |

The following table shows the bit definition of DES3.

**Table 3-9 DES3 Definition**

| Bits | Name                    | Descriptor                                                                                                                            |
|------|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | Next descriptor address | NEXT_DESP_ADDR<br>The bits indicate the pointer to the physical memory where the next descriptor is present.<br>It is a word address. |

### 3.3.3.8 Calibrating the Delay Chain

There are two delay chains in SMHC: data strobe delay chain and sample delay chain.

- Data strobe delay chain: used to generate delay to make proper timing between Data Strobe and data signals.
- Sample delay chain: used to generate delay to make proper timing between the internal card clock signal and data signals.

Each delay chain is made up with 64 delay cells. The delay time of one delay cell can be estimated through delay chain calibration.

Follow the steps below to calibrate the delay chain:

**Step 1** Enable SMHC. In order to calibrate the delay chain by the operation registers in SMHC, the SMHC must be enabled through [SMHC Bus Gating Reset Register](#) and [SMHCx Clock Register\(x=0, 1, or 2\)](#).

**Step 2** Configure a proper clock for SMHC. The delay chain calibration is based on the clock for SMHC from Clock Control Unit (CCU). The delay chain calibration is an internal function in SMHC and needs no devices. So it is unnecessary to open the clock signal for devices. The recommended clock frequency is 200 MHz.

**Step 3** Set proper initial delay value. Writing 0xA0 to delay control register enables Delay Software Enable (bit [7]) and sets initial delay value 0x20 to Delay chain (bit [5:0]). Then write 0x0 to delay control register to clear the value.

**Step 4** Write 0x8000 to delay control register to start calibrating the delay chain.

**Step 5** Wait until the flag (bit14 in delay control register) of calibration done is set. The number of delay cells is shown at bit [13:8] in delay control register. The delay time generated by

these delay cells is equal to the cycle of the SMHC clock nearly. This value is the result of calibration.

- Step 6** Calculate the delay time of one delay cell according to the cycle of the SMHC clock and the result of calibration.

### 3.3.4 Programming Guidelines

#### 3.3.4.1 Initializing SMHC

Before data and commands are exchanged between a card and the SMHC, the SMHC needs to be initialized. Follow the steps below to initialize the SMHC:

- Step 1** Configure the corresponding GPIO register as an SMHC in section 8.5 GPIO; reset clock by writing 1 to [SMHC\\_BGR\\_REG](#)[SMHC<sub>x</sub>\_RST](x=0, 1, or 2), and open clock gating by writing 1 to [SMHC\\_BGR\\_REG](#)[SMHC<sub>x</sub>\_GATING] (x=0, 1, or 2); select clock sources and set the division factor by configuring the [SMHC<sub>x</sub>\\_CLK\\_REG](#) (x = 0, 1, or 2) register.
- Step 2** Configure [SMHC\\_CTRL](#) to reset the FIFO and controller, and enable the global interrupt; configure [SMHC\\_INTMASK](#) to 0xFFCE to enable normal interrupts and error abnormal interrupts, and then register the interrupt function.
- Step 3** Configure [SMHC\\_CLKDIV](#) to open clock for devices; configure [SMHC\\_CMD](#) as the change clock command (for example 0x80202000); send the update clock command to deliver clocks to devices.
- Step 4** Configure [SMHC\\_CMD](#) as a normal command. Configure [SMHC\\_CMDARG](#) to set command parameters. Configure [SMHC\\_CMD](#) to set parameters like whether to send the response, the response type, and the response length and then send the commands. According to the initialization process in the protocol, you can finish SMHC initialization by sending the corresponding command one by one.

#### 3.3.4.2 Writing a Single Data Block

To write a single data block, follow the steps below:

- Step 1** Write 0x1 to [SMHC\\_CTRL](#)[DMA\_RST] to reset the internal DMA controller; write 0x82 to [SMHC\\_IDMAC](#) to enable the IDMAC interrupt and configure AHB master burst transfers; configure [SMHC\\_IDIE](#) to enable the transfer interrupt, receive interrupt, and abnormal interrupt.
- Step 2** Configure [SMHC\\_FIFOTH](#) to determine the burst size and TX/RX trigger level. For example, if [SMHC\\_FIFOTH](#) is configured as 0x300F00F0, it indicates the burst size is 16, TX\_TL is 15, and RX\_TL is 240. Configure [SMHC\\_DLBA](#) to determine the start address of the DMA descriptor.

- Step 3** To write one block data to sector1, configure [SMHC\\_BYTCNT](#)[BYTE\_CNT] to 0x200 and configure the descriptor according to the data size; set the data sector address of CMD24 (Single Data Block Write) to 0x1, write 0x800002758 to [SMHC\\_CMD](#), and send CMD24 command to write data to the device.
- Step 4** Check whether [SMHC\\_RINTSTS](#)[CC] is 1. If yes, the command is sent successfully; otherwise, continue to wait until timeout, and then exit the process.
- Step 5** Check whether [SMHC\\_IDST](#)[TX\_INT] is 1. If yes, the data transfer for writing DMA is completed. Write 0x337 to [SMHC\\_IDST](#) to clear the interrupt flag. Otherwise, continue to wait until timeout, and then exit the process.
- Step 6** Check whether [SMHC\\_RINTSTS](#)[DTC] is 1. If yes, the data transfer and CMD24 writing operations are completed. Otherwise, abnormality exists. Read [SMHC\\_RINTSTS](#) and [SMHC\\_STATUS](#) to query the existing abnormality.
- Step 7** Send CMD13 command to query whether the device writing operation is completed and returns to the idle status. For example, device RCA is 0x1234, first set [SMHC\\_CMDARG](#) to 0x12340000, write 0x8000014D to [SMHC\\_CMD](#), go to step4 to ensure command transfer completed, and then check whether the highest bit of [SMHC\\_RESP0](#) (CMD13 response) is 1. If yes, the device is in the idle status, and the next command can be sent. Otherwise, the device is in the busy status. Continue to send CMD13 to wait for the device to enter the idle status until timeout.

### 3.3.4.3 Reading a Single Data Block

To read a single data block, follow the steps below:

- Step 1** Write 0x1 to [SMHC\\_CTRL](#)[DMA\_RST] to reset the internal DMA controller; write 0x82 to [SMHC\\_IDMAC](#) to enable the IDMAC interrupt and configure AHB master burst transfers; configure [SMHC\\_IDIE](#) to enable the transfer interrupt, receive interrupt, and abnormal interrupt.
- Step 2** Configure [SMHC\\_FIFOTH](#) to determine the burst size and TX/RX trigger level. For example, if [SMHC\\_FIFOTH](#) is configured as 0x300F00F0, it indicates the burst size is 16, TX\_TL is 15, and RX\_TL is 240. Configure [SMHC\\_DLBA](#) to determine the start address of the DMA descriptor.
- Step 3** To read one block data from sector1, configure [SMHC\\_BYTCNT](#)[BYTE\_CNT] to 0x200 and configure the descriptor according to the data size; set the data sector address of CMD17 command (Single Data Block Read) to 0x1, write 0x80002351 to [SMHC\\_CMD](#), and send CMD17 command to read data from the device to DRAM/SRAM.
- Step 4** Check whether [SMHC\\_RINTSTS](#)[CC] is 1. If yes, the command is sent successfully; otherwise, continue to wait until timeout, and then exit the process.

- Step 5** Check whether [SMHC\\_IDST](#)[TX\_INT] is 1. If yes, the data transfer for writing DMA is completed. Write 0x337 to [SMHC\\_IDST](#) to clear the interrupt flag. Otherwise, continue to wait until timeout, and then exit the process.
- Step 6** Check whether [SMHC\\_RINTSTS](#)[DTC] is 1. If yes, data transfer and CMD17 reading operation are completed. Otherwise, abnormality exists. Read [SMHC\\_RINTSTS](#) and [SMHC\\_STATUS](#) to query the existing abnormality.

### 3.3.4.4 Writing Open-Ended Multiple Data Blocks (CMD25 + Auto CMD12)

To write open-ended multiple data blocks, follow the steps below:

- Step 1** Write 0x1 to [SMHC\\_CTRL](#)[DMA\_RST] to reset the internal DMA controller; write 0x82 to [SMHC\\_IDMAC](#) to enable the IDMAC interrupt and configure AHB master burst transfers; configure [SMHC\\_IDIE](#) to enable the transfer interrupt, receive interrupt, and abnormal interrupt.
- Step 2** Configure [SMHC\\_FIFOTH](#) to determine the burst size and TX/RX trigger level. For example, if [SMHC\\_FIFOTH](#) is configured as 0x300F00F0, it indicates the burst size is 16, TX\_TL is 15, and RX\_TL is 240. Configure [SMHC\\_DLBA](#) to determine the start address of the DMA descriptor.
- Step 3** To write three blocks of data to sectors begin with sector0, configure [SMHC\\_BYTCNT](#)[BYTE\_CNT] to 0x600 and configure the descriptor according to the data size; set the data sector address of CMD25 command (Multiple Data Blocks Write) to 0x0, write 0x80003759 to [SMHC\\_CMD](#), and send CMD25 command to read data from the device to DRAM/SRAM.
- Step 4** Check whether [SMHC\\_RINTSTS](#)[CC] is 1. If yes, the command is sent successfully; otherwise, continue to wait until timeout, and then exit the process.
- Step 5** Check whether [SMHC\\_IDST](#)[TX\_INT] is 1. If yes, the data transfer for writing DMA is completed. Write 0x337 to [SMHC\\_IDST](#) to clear the interrupt flag. Otherwise, continue to wait until timeout, and then exit the process.
- Step 6** Check whether [SMHC\\_RINTSTS](#)[ACD] and [SMHC\\_RINTSTS](#)[DTC] are both 1. If yes, the data transfer, CMD12 transfer, and CMD25 writing operations are completed. Otherwise, abnormality exists. Read [SMHC\\_RINTSTS](#) and [SMHC\\_STATUS](#) to query the existing abnormality.
- Step 7** Send CMD13 command to query whether the device writing operation is completed and returns to the idle status. For example, device RCA is 0x1234, first set [SMHC\\_CMDARG](#) to 0x12340000, write 0x8000014D to [SMHC\\_CMD](#), go to step4 to ensure command transfer completed, and then check whether the highest bit of [SMHC\\_RESP0](#) (CMD13 response) is 1. If yes, the device is in the idle status, and the next command can be sent. Otherwise,

the device is in the busy status. Continue to send CMD13 to wait for the device to enter the idle status until timeout.

### 3.3.4.5 Reading Open-Ended Multiple Data Blocks (CMD18 + Auto CMD12)

To read open-ended multiple data blocks, follow the steps below:

- Step 1** Write 0x1 to [SMHC\\_CTRL](#)[DMA\_RST] to reset the internal DMA controller; write 0x82 to [SMHC\\_IDMAC](#) to enable the IDMAC interrupt and configure AHB master burst transfers; configure [SMHC\\_IDIE](#) to enable the transfer interrupt, receive interrupt, and abnormal interrupt.
- Step 2** Configure [SMHC\\_FIFOTH](#) to determine the burst size and TX/RX trigger level. For example, if [SMHC\\_FIFOTH](#) is configured as 0x300F00F0, it indicates the burst size is 16, TX\_TL is 15, and RX\_TL is 240. Configure [SMHC\\_DLBA](#) to determine the start address of the DMA descriptor.
- Step 3** To read three blocks of data from sectors begin with sector0, configure [SMHC\\_BYTCNT](#)[BYTE\_CNT] to 0x600 and configure the descriptor according to the data size; set the data sector address of CMD18 command (Multiple Data Blocks Read) to 0x0, write 0x80003352 to [SMHC\\_CMD](#), and send CMD18 command to read data to the device. When the data transfer is completed, CMD12 will be sent automatically.
- Step 4** Check whether [SMHC\\_RINTSTS](#)[CC] is 1. If yes, the command is sent successfully; otherwise, continue to wait until timeout, and then exit the process.
- Step 5** Check whether [SMHC\\_IDST](#)[RX\_INT] is 1. If yes, the data transfer for writing DMA is completed. Write 0x337 to [SMHC\\_IDST](#) to clear the interrupt flag. Otherwise, continue to wait until timeout, and then exit the process.
- Step 6** Check whether [SMHC\\_RINTSTS](#)[ACD] and [SMHC\\_RINTSTS](#)[DTC] are both 1. If yes, data transfer, CMD12 transfer, and CMD18 reading operation are completed. Otherwise, abnormality exists. Read [SMHC\\_RINTSTS](#) and [SMHC\\_STATUS](#) to query the existing abnormality.

### 3.3.4.6 Writing Pre-Defined Multiple Data Blocks (CMD23 + CMD25)

To write pre-defined multiple data blocks, follow the steps below:

- Step 1** Write 0x1 to [SMHC\\_CTRL](#)[DMA\_RST] to reset the internal DMA controller; write 0x82 to [SMHC\\_IDMAC](#) to enable the IDMAC interrupt and configure AHB master burst transfers; configure [SMHC\\_IDIE](#) to enable the transfer interrupt, receive interrupt, and abnormal interrupt.

- Step 2** Configure [SMHC\\_FIFOTH](#) to determine the burst size and TX/RX trigger level. For example, if [SMHC\\_FIFOTH](#) is configured as 0x300F00F0, it indicates the burst size is 16, TX\_TL is 15, and RX\_TL is 240. Configure [SMHC\\_DLBA](#) to determine the start address of the DMA descriptor.
- Step 3** To write three blocks of data, configure [SMHC\\_CMDARG](#) to 0x3 to specify the number of data blocks as three. Then write 0x80000157 to [SMHC\\_CMD](#) to send the CMD23 command. Check whether [SMHC\\_RINTSTS](#)[CC] is 1. If yes, the command is sent successful; otherwise, continue to wait until timeout, and then exit the process.
- Step 4** Configure [SMHC\\_BYTCNT](#)[BYTE\_CNT] to 0x600 and configure the descriptor according to the data size; set the data sector address of CMD25 command (Multiple Data Blocks Write) to 0x0, write 0x80002759 to [SMHC\\_CMD](#), and send CMD25 command to write data to the device.
- Step 5** Check whether [SMHC\\_RINTSTS](#)[CC] is 1. If yes, the command is sent successful; otherwise, continue to wait until timeout, and then exit the process.
- Step 6** Check whether [SMHC\\_IDST](#)[TX\_INT] is 1. If yes, the data transfer for writing DMA is completed. Write 0x337 to [SMHC\\_IDST](#) to clear the interrupt flag. Otherwise, continue to wait until timeout, and then exit the process.
- Step 7** Check whether [SMHC\\_RINTSTS](#)[DTC] is 1. If yes, the data transfer and CMD25 writing operations are completed. Otherwise, abnormality exists. Read [SMHC\\_RINTSTS](#) and [SMHC\\_STATUS](#) to query the existing abnormality.
- Step 8** Send CMD13 command to query whether the device writing operation is completed and returns to the idle status. For example, device RCA is 0x1234, first set [SMHC\\_CMDARG](#) to 0x12340000, write 0x8000014D to [SMHC\\_CMD](#), go to step5 to ensure command transfer completed, and then check whether the highest bit of [SMHC\\_RESP0](#) (CMD13 response) is 1. If yes, the device is in the idle status, and the next command can be sent. Otherwise, the device is in the busy status. Continue to send CMD13 to wait for the device to enter the idle status until timeout

### 3.3.4.7 Reading Pre-Defined Multiple Data Blocks (CMD23 + CMD18)

To read pre-defined multiple data blocks, follow the steps below:

- Step 1** Write 0x1 to [SMHC\\_CTRL](#)[DMA\_RST] to reset the internal DMA controller; write 0x82 to [SMHC\\_IDMAC](#) to enable the IDMAC interrupt and configure AHB master burst transfers; configure [SMHC\\_IDIE](#) to enable the transfer interrupt, receive interrupt, and abnormal interrupt.
- Step 2** Configure [SMHC\\_FIFOTH](#) to determine the burst size and TX/RX trigger level. For example, if [SMHC\\_FIFOTH](#) is configured as 0x300F00F0, it indicates the burst size is 16,

TX\_TL is 15, and RX\_TL is 240. Configure [SMHC\\_DLBA](#) to determine the start address of the DMA descriptor.

- Step 3** To read three blocks of data, configure [SMHC\\_CMDARG](#) to 0x3 to specify the number of data blocks as three. Then write 0x80000157 to [SMHC\\_CMD](#) to send the CMD23 command. Check whether [SMHC\\_RINTSTS](#)[CC] is 1. If yes, the command is sent successful; otherwise, continue to wait until timeout, and then exit the process.
- Step 4** Configure [SMHC\\_BYTCNT](#)[BYTE\_CNT] to 0x600 and configure the descriptor according to the data size; set the data sector address of CMD18 (Multiple Data Blocks Read) to 0x0, write 0x80002352 to [SMHC\\_CMD](#), and send CMD18 command to read data from device to DRAM/SRAM.
- Step 5** Check whether [SMHC\\_RINTSTS](#)[CC] is 1. If yes, the command is sent successful; otherwise, continue to wait until timeout, and then exit the process.
- Step 6** Check whether [SMHC\\_IDST](#)[RX\_INT] is 1. If yes, the data transfer for writing DMA is completed. Write 0x337 to [SMHC\\_IDST](#) to clear the interrupt flag. Otherwise, continue to wait until timeout, and then exit the process.
- Step 7** Check whether [SMHC\\_RINTSTS](#)[DTC] is 1. If yes, the data transfer and CMD18 writing operations are completed. Otherwise, abnormality exists. Read [SMHC\\_RINTSTS](#) and [SMHC\\_STATUS](#) to query the existing abnormality.

### 3.3.4.8 Initializing Command Queue for eMMC V5.1 Device

The following figure describes the initialization process of command queue.

Figure 3-10 Initialization Process of Command Queue



Follow the steps below to initialize the command queue:

- Step 1** Initialize the eMMC. For detailed initialization steps, refer to section 3.3.4.1 Initializing SMHC.
- Step 2** Send CMD6 to configure the timing mode and bus width. Send CMD16 to configure the block size as 512 B.



The block size must be set to 512 B. After the command queue is enabled, the block size will not be able to be modified.

- Step 3** Send CMD6 to enable the command queue of the eMMC device.

---

**Step 4** Configure [CQTDLBA](#) register to set the base address of the task descriptor list.

---



#### NOTE

When the base address of the task descriptor list crosses 4 GB, you need to write the bit [32] of the higher 32-bit address to the bit [0] of the CQTDLBA register and write the lower 32-bit address to the CQTDLBA register.

For example, assume that the base address is 0x106000000. In this case, you need to write the bit [32] of the higher 32-bit address to the bit [0] of the CQTDLBA register and write 0x06000001 to the CQTDLBA register.

---

**Step 5** Configure [CQSSC1](#) register to set how to query the status of the device's task queue.

**Step 6** Configure [CQIC](#) register to enable/disable interrupt, set interrupt count and timer protection.

**Step 7** Configure [CQRMEM](#) register to set which errors may trigger a RED interrupt.

**Step 8** Configure [CQCFG](#) register to enable CQE activity.

eMMC CMDQ supports multiple operation modes, which could be selected by configuring the CMDQ\_MODE bit (bit [5:4]) of [CQCFG](#) register.

### 3.3.5 Register List

| Module Name | Base Address | Description                           |
|-------------|--------------|---------------------------------------|
| SMHC0       | 0x04020000   |                                       |
| SMHC1       | 0x04021000   | SMHC1 register is the same with SMHC0 |
| SMHC2       | 0x04022000   | SMHC2 register is the same with SMHC0 |

| Register Name | Offset | Description                    |
|---------------|--------|--------------------------------|
| SMHC_CTRL     | 0x0000 | SMHC Global Control Register   |
| SMHC_CLKDIV   | 0x0004 | SMHC Clock Control Register    |
| SMHC_TMOUT    | 0x0008 | SMHC Timeout Register          |
| SMHC_CTYPE    | 0x000C | SMHC Bus Width Register        |
| SMHC_BLKSIZ   | 0x0010 | SMHC Block Size Register       |
| SMHC_BYTCNT   | 0x0014 | SMHC Byte Count Register       |
| SMHC_CMD      | 0x0018 | SMHC Command Register          |
| SMHC_CMDARG   | 0x001C | SMHC Command Argument Register |
| SMHC_RESP0    | 0x0020 | SMHC Response 0 Register       |
| SMHC_RESP1    | 0x0024 | SMHC Response 1 Register       |
| SMHC_RESP2    | 0x0028 | SMHC Response 2 Register       |
| SMHC_RESP3    | 0x002C | SMHC Response 3 Register       |
| SMHC_INTMASK  | 0x0030 | SMHC Interrupt Mask Register   |

| Register Name     | Offset | Description                                           |
|-------------------|--------|-------------------------------------------------------|
| SMHC_MINTSTS      | 0x0034 | SMHC Masked Interrupt Status Register                 |
| SMHC_RINTSTS      | 0x0038 | SMHC Raw Interrupt Status Register                    |
| SMHC_STATUS       | 0x003C | SMHC Status Register                                  |
| SMHC_FIFOTH       | 0x0040 | SMHC FIFO Water Level Register                        |
| SMHC_FUNS         | 0x0044 | SMHC FIFO Function Select Register                    |
| SMHC_TBC0         | 0x0048 | SMHC Transferred Byte Count Register 0                |
| SMHC_TBC1         | 0x004C | SMHC Transferred Byte Count Register 1                |
| SMHC_CSDC         | 0x0054 | SMHC CRC Status Detect Control Register               |
| SMHC_A12A         | 0x0058 | SMHC Auto Command 12 Argument Register                |
| SMHC_NTSR         | 0x005C | SMHC New Timing Set Register                          |
| SMHC_HWRST        | 0x0078 | SMHC Hardware Reset Register                          |
| SMHC_IDMAC        | 0x0080 | SMHC IDMAC Control Register                           |
| SMHC_DLBA         | 0x0084 | SMHC Descriptor List Base Address Register            |
| SMHC_IDST         | 0x0088 | SMHC IDMAC Status Register                            |
| SMHC_IDIE         | 0x008C | SMHC IDMAC Interrupt Enable Register                  |
| SMHC_THLD         | 0x0100 | SMHC Card Threshold Control Register                  |
| SMHC_SFC          | 0x0104 | SMHC Sample FIFO Control Register                     |
| SMHC_A23A         | 0x0108 | SMHC Auto Command 23 Argument Register                |
| EMMC_DDR_SBIT_DET | 0x010C | SMHC eMMC4.5 DDR Start Bit Detection Control Register |
| SMHC_EXT_CMD      | 0x0138 | SMHC Extended Command Register                        |
| SMHC_EXT RESP     | 0x013C | SMHC Extended Response Register                       |
| SMHC_DRV_DL       | 0x0140 | SMHC Drive Delay Control Register                     |
| SMHC_SAMP_DL      | 0x0144 | SMHC Sample Delay Control Register                    |
| SMHC_DS_DL        | 0x0148 | SMHC Data Strobe Delay Control Register               |
| SMHC_HS400_DL     | 0x014C | SMHC HS400 New Timing Delay Control Register          |
| SMHC_CIU_CNT      | 0x0154 | SMHC Card interface counter                           |
| SMHC_FIFO         | 0x0200 | SMHC FIFO Register                                    |
| CQCFG             | 0x0408 | Command Queuing Configuration                         |
| CQCTL             | 0x040C | Command Queuing Control                               |
| CQIS              | 0x0410 | Command Queuing Interrupt Status                      |
| CQISTE            | 0x0414 | Command Queuing Interrupt Status Enable               |
| CQISGE            | 0x0418 | Command Queuing Interrupt Signal Enable               |
| CQIC              | 0x041C | Command Queuing Interrupt Coalescing                  |
| CQTDLBA           | 0x0420 | Command Queuing Task Descriptor List Base Address     |
| CQTDBR            | 0x0428 | Command Queuing Task Doorbell                         |
| CQTCN             | 0x042C | Command Queuing Task Completion Notification          |
| CQDQS             | 0x0430 | Command Queuing Device Queue Status                   |
| CQDPT             | 0x0434 | Command Queuing Device Pending Tasks                  |
| CQTCLR            | 0x0438 | Command Queuing Task Clear                            |
| CQSSC1            | 0x0440 | Command Queuing Send Status Configuration 1           |

| Register Name | Offset | Description                                              |
|---------------|--------|----------------------------------------------------------|
| CQSSC2        | 0x0444 | Command Queuing Send Status Configuration 2              |
| CQCRDCT       | 0x0448 | Command Queuing Command Response for Direct-Command Task |
| CQRMEM        | 0x0450 | Command Queuing Response Mode Error Mask                 |
| CQTERRI       | 0x0454 | Command Queuing Task Error Information                   |
| CQCRI         | 0x0458 | Command Queuing Command Response Index                   |
| CQCRA         | 0x045C | Command Queuing Command Response Argument                |

### 3.3.6 Register Description

#### 3.3.6.1 0x0000 SMHC Global Control Register (Default Value: 0x0000\_0100)

| Offset: 0x0000 |            |             | Register Name: SMHC_CTRL                                                                                                                                                         |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                      |
| 31             | R/W        | 0x0         | FIFO_AC_MOD<br>FIFO Access Mode<br>1: AHB bus<br>0: DMA bus                                                                                                                      |
| 30:18          | /          | /           | /                                                                                                                                                                                |
| 17:16          | R/W        | 0x0         | SRAM_BIST_SEL<br>SRAM BIST Select<br>2'b00: for SMHC 4K SRAM(1024x32) BIST<br>2'b01: for CQE SRAM(32x56) BIST<br>2'b10: for EMCE SRAM BIST<br>2'b11: Reserved                    |
| 15:13          | /          | /           | /                                                                                                                                                                                |
| 12             | R/W        | 0x0         | TIME_UNIT_CMD<br>Time unit for command line<br>Time unit used to calculate command line time out value defined in RTO_LMT.<br>0: 1 card clock period<br>1: 256 card clock period |
| 11             | R/W        | 0x0         | TIME_UNIT_DAT<br>Time unit for data line<br>Time unit used to calculate data line time out value defined in DTO_LMT.<br>0: 1 card clock period<br>1: 256 card clock period       |
| 10             | R/W        | 0x0         | DDR_MOD_SEL<br>DDR Mode Select<br>Although the HS400 speed mode of eMMC is 8-bit DDR, this field should be cleared when                                                          |

| Offset: 0x0000 |            |             | Register Name: SMHC_CTRL                                                                                                                  |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                               |
|                |            |             | HS400_MD_EN is set.<br>0: SDR mode<br>1: DDR mode                                                                                         |
| 9              | /          | /           | /                                                                                                                                         |
| 8              | R/W        | 0x1         | CD_DBC_ENB<br>Card Detect (Data [3] status) De-bounce Enable<br>0: Disable de-bounce<br>1: Enable de-bounce                               |
| 7:6            | /          | /           | /                                                                                                                                         |
| 5              | R/W        | 0x0         | DMA_ENB<br>DMA Global Enable<br>0: Disable DMA to transfer data, using AHB bus<br>1: Enable DMA to transfer data                          |
| 4              | R/W        | 0x0         | INT_ENB<br>Global Interrupt Enable<br>0: Disable interrupts<br>1: Enable interrupts                                                       |
| 3              | /          | /           | /                                                                                                                                         |
| 2              | R/W        | 0x0         | DMA_RST<br>DMA Reset                                                                                                                      |
| 1              | R/W        | 0x0         | FIFO_RST<br>FIFO Reset<br>0: No change<br>1: Reset FIFO<br>This bit is auto-cleared after completion of reset operation.                  |
| 0              | R/W        | 0x0         | SOFT_RST<br>Software Reset<br>0: No change<br>1: Reset SD/MMC controller<br>This bit is auto-cleared after completion of reset operation. |

### 3.3.6.2 0x0004 SMHC Clock Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0004 |            |             | Register Name: SMHC_CLKDIV                                                                           |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                          |
| 31             | R/W        | 0x0         | MASK_DAT0<br>Mask Data0<br>0: Do not mask data0 when update clock<br>1: Mask data0 when update clock |

| Offset: 0x0004 |            |             | Register Name: SMHC_CLKDIV                                                                                                            |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                           |
| 30:18          | /          | /           | /                                                                                                                                     |
| 17             | R/W        | 0x0         | CCLK_CTRL<br>Card Clock Output Control<br>0: Card clock always on<br>1 : Turn off card clock when FSM in IDLE state                   |
| 16             | R/W        | 0x0         | CCLK_ENB<br>Card Clock Enable<br>0: Card Clock off<br>1: Card Clock on                                                                |
| 15:8           | /          | /           | /                                                                                                                                     |
| 7:0            | R/W        | 0x0         | CCLK_DIV<br>Card clock divider<br>n: Source clock is divided by 2*n.(n=0-255)<br>when HS400_MD_EN is set, this field must be cleared. |

### 3.3.6.3 0x0008 SMHC Timeout Register (Default Value:0xFFFF\_FF40)

| Offset: 0x0008 |            |             | Register Name: SMHC_TMOUT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 31:8           | R/W        | 0xffffffff  | <p>DTO_LMT<br/>Data Timeout Limit<br/>This field can set time of the Host wait for the data from the Device.<br/>Ensure to communicate with the Device, this field must be set to maximum that greater than the time <math>N_{AC}</math>.<br/>About the <math>N_{AC}</math>, the explanation is as follows:<br/>When Host read data, data transmission from the Device starts after the access time delay <math>N_{AC}</math> beginning from the end bit of the read command(ACMD51,CMD8,CMD17,CMD18).<br/>When Host read multiple block(CMD18),the next block's data transmission from the Device starts after the access time delay <math>N_{AC}</math> beginning from the end bit of the previous block.<br/>When Host write data, this value is no effect.<br/>Note: Under the following 3 conditions, the timeout limit is half of the set time.<br/>1&gt; DDR8 mode<br/>2&gt; DDR4 and <a href="#">SMHC_NTSR[MODE_SELEC]</a> (0x5C [31])</p> |

| Offset: 0x0008 |            |             | Register Name: SMHC_TMOUT                                                                |
|----------------|------------|-------------|------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                              |
|                |            |             | high<br>3> HS400 and<br><a href="#">SMHC_NTSR</a> [HS400_NEW_SAMPLE_EN](0x5C[0])<br>high |
| 7:0            | R/W        | 0x40        | RTO_LMT<br>Response Timeout Limit                                                        |

### 3.3.6.4 0x000C SMHC Bus Width Register (Default Value:0x0000\_0000)

| Offset: 0x000C |            |             | Register Name: SMHC_CTYPE                                                       |
|----------------|------------|-------------|---------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                     |
| 31:2           | /          | /           | /                                                                               |
| 1:0            | R/W        | 0x0         | CARD_WID<br>Card width<br>00: 1-bit width<br>01: 4-bit width<br>1x: 8-bit width |

### 3.3.6.5 0x0010 SMHC Block Size Register (Default Value:0x0000\_0200)

| Offset: 0x0010 |            |             | Register Name: SMHC_BLKSIZ |
|----------------|------------|-------------|----------------------------|
| Bit            | Read/Write | Default/Hex | Description                |
| 31:16          | /          | /           | /                          |
| 15:0           | R/W        | 0x200       | BLK_SZ<br>Block size       |

### 3.3.6.6 0x0014 SMHC Byte Count Register (Default Value:0x0000\_0200)

| Offset: 0x0014 |            |             | Register Name: SMHC_BYTCNT                                                                                                            |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                           |
| 31:0           | R/W        | 0x200       | BYTE_CNT<br>Byte counter<br>Number of bytes to be transferred. It must be integer multiple of Block Size(BLK_SZ) for block transfers. |

### 3.3.6.7 0x0018 SMHC Command Register (Default Value:0x0000\_0000)

| Offset: 0x0018 | Register Name: SMHC_CMD |
|----------------|-------------------------|
|----------------|-------------------------|

| Bit   | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                |
|-------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | R/W        | 0x0         | CMD_LOAD<br>Start Command.<br>This bit is auto cleared when current command is sent. If there is no any response error happened, a command complete interrupt bit will be set in <a href="#">SMHC_RINTSTS</a> register. You should not write any other command before this bit is cleared. |
| 30:29 | /          | /           | /                                                                                                                                                                                                                                                                                          |
| 28    | R/W        | 0x0         | VOL_SW<br>Voltage Switch<br>0: normal command<br>1: Voltage switch command, set for CMD11 only                                                                                                                                                                                             |
| 27    | R/W        | 0x0         | BOOT_ABST<br>Boot Abort<br>Setting this bit will terminate the boot operation.                                                                                                                                                                                                             |
| 26    | R/W        | 0x0         | EXP_BOOT_ACK<br>Expect Boot Acknowledge.<br>When Software sets this bit along in mandatory boot operation, controller expects a boot acknowledge start pattern of 0-1-0 from the selected card.                                                                                            |
| 25:24 | R/W        | 0x0         | BOOT_MOD<br>Boot Mode<br>00: Normal command<br>01: Mandatory Boot operation<br>10: Alternate Boot operation<br>11: Reserved                                                                                                                                                                |
| 23:22 | /          | /           | /                                                                                                                                                                                                                                                                                          |
| 21    | R/W        | 0x0         | PRG_CLK<br>Change Clock<br>0: Normal command<br>1: Change Card Clock;<br>When this bit is set, controller will change clock domain and clock output. No command will be sent.                                                                                                              |
| 20:18 | /          | /           | /                                                                                                                                                                                                                                                                                          |
| 17    | R/W        | 0x0         | R1B_BUSY_HW_DETECT<br>R1b busy hardware detect enable<br>0: Disable hardware detect r1b busy<br>1: Enable hardware detect r1b busy                                                                                                                                                         |
| 16    | R/W        | 0x0         | R1B_RESP<br>R1b response<br>0: The response type isn't r1b for current command<br>1: The response type is r1b for current command                                                                                                                                                          |

| Offset: 0x0018 |            |             | Register Name: SMHC_CMD                                                                                                                                                                                                                     |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                 |
|                |            |             | Note: if STOP_CMD_FLAG set, R1B_RESP will be set by controller when send CMD12, and will be clear by controller when send next command.                                                                                                     |
| 15             | R/W        | 0x0         | SEND_INIT_SEQ<br>Send Initialization<br>0: normal command sending<br>1: Send initialization sequence before sending this command.                                                                                                           |
| 14             | R/W        | 0x0         | STOP_ABT_CMD<br>Stop Abort Command<br>0: normal command sending<br>1: send Stop or abort command to stop current data transfer in progress.(CMD12, CMD52 for writing "I/O Abort" in SDIO CCCR)                                              |
| 13             | R/W        | 0x0         | WAIT_PRE_OVER<br>Wait Data Transfer Over<br>0: Send command at once, do not care of data transferring<br>1: Wait for data transfer completion before sending current command                                                                |
| 12             | R/W        | 0x0         | STOP_CMD_FLAG<br>Send Stop CMD Automatically (CMD12)<br>0: Do not send stop command at end of data transfer<br>1: Send stop command automatically at end of data transfer<br>If set, the SMHC_RESP1 will record the response of auto CMD12. |
| 11             | R/W        | 0x0         | TRANS_MODE<br>Transfer Mode<br>0: Block data transfer command<br>1: Stream data transfer command                                                                                                                                            |
| 10             | R/W        | 0x0         | TRANS_DIR<br>Transfer Direction<br>0: Read operation<br>1: Write operation                                                                                                                                                                  |
| 9              | R/W        | 0x0         | DATA_TRANS<br>Data Transfer<br>0: without data transfer<br>1: with data transfer                                                                                                                                                            |
| 8              | R/W        | 0x0         | CHK_RESP_CRC                                                                                                                                                                                                                                |

| Offset: 0x0018 |            |             | Register Name: SMHC_CMD                                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                              |
|                |            |             | Check Response CRC<br>0: Do not check response CRC<br>1: Check response CRC              |
| 7              | R/W        | 0x0         | LONG_RESP<br>Response Type<br>0: Short Response (48 bits)<br>1: Long Response (136 bits) |
| 6              | R/W        | 0x0         | RESP_RCV<br>Response Receive<br>0: Command without Response<br>1: Command with Response  |
| 5:0            | R/W        | 0x0         | CMD_IDX<br>CMD Index<br>Command index value                                              |

### 3.3.6.8 0x001C SMHC Command Argument Register (Default Value: 0x0000\_0000)

| Offset: 0x001C |            |             | Register Name: SMHC_CMDARG  |
|----------------|------------|-------------|-----------------------------|
| Bit            | Read/Write | Default/Hex | Description                 |
| 31:0           | R/W        | 0x0         | CMD_ARG<br>Command argument |

### 3.3.6.9 0x0020 SMHC Response 0 Register (Default Value: 0x0000\_0000)

| Offset: 0x0020 |            |             | Register Name: SMHC_RESP0                        |
|----------------|------------|-------------|--------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                      |
| 31:0           | R          | 0x0         | CMD_RESP0<br>Response 0<br>Bit[31:0] of response |

### 3.3.6.10 0x0024 SMHC Response 1 Register (Default Value: 0x0000\_0000)

| Offset: 0x0024 |            |             | Register Name: SMHC_RESP1                         |
|----------------|------------|-------------|---------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                       |
| 31:0           | R          | 0x0         | CMD_RESP1<br>Response 1<br>Bit[63:32] of response |

### 3.3.6.11 0x0028 SMHC Response 2 Register (Default Value: 0x0000\_0000)

| Offset: 0x0028 |            |             | Register Name: SMHC_RESP2                         |
|----------------|------------|-------------|---------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                       |
| 31:0           | R          | 0x0         | CMD_RESP2<br>Response 2<br>Bit[95:64] of response |

### 3.3.6.12 0x002C SMHC Response 3 Register (Default Value: 0x0000\_0000)

| Offset: 0x002C |            |             | Register Name: SMHC_RESP3                          |
|----------------|------------|-------------|----------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                        |
| 31:0           | R          | 0x0         | CMD_RESP3<br>Response 3<br>Bit[127:96] of response |

### 3.3.6.13 0x0030 SMHC Interrupt Mask Register (Default Value: 0x0000\_0000)

| Offset: 0x0030 |            |             | Register Name: SMHC_INTMASK                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                  |
| 31             | R/W        | 0x0         | CARD_REMOVAL_INT_EN<br>Card Removed Interrupt Enable                         |
| 30             | R/W        | 0x0         | CARD_INSERT_INT_EN<br>Card Inserted Interrupt Enable                         |
| 29:18          | /          | /           | /                                                                            |
| 17             | R/W        | 0x0         | R1B_BUSY_CLR_INT_EN                                                          |
| 16             | R/W        | 0x0         | SDIO_INT_EN<br>SDIO Interrupt Enable                                         |
| 15             | R/W        | 0x0         | DEE_INT_EN<br>Data End-bit Error Interrupt Enable                            |
| 14             | R/W        | 0x0         | ACD_INT_EN<br>Auto Command Done Interrupt Enable                             |
| 13             | R/W        | 0x0         | DSE_BC_INT_EN<br>Data Start Error Interrupt Enable                           |
| 12             | R/W        | 0x0         | CB_IW_INT_EN<br>Command Busy and Illegal Write Interrupt Enable              |
| 11             | R/W        | 0x0         | FU_FO_INT_EN<br>FIFO Underrun/Overflow Interrupt Enable                      |
| 10             | R/W        | 0x0         | DSTO_VSD_INT_EN<br>Data Starvation Timeout/V1.8 Switch Done Interrupt Enable |
| 9              | R/W        | 0x0         | DTO_BDS_INT_EN                                                               |

| Offset: 0x0030 |            |             | Register Name: SMHC_INTMASK                                            |
|----------------|------------|-------------|------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                            |
|                |            |             | Data Timeout/Boot Data Start Interrupt Enable                          |
| 8              | R/W        | 0x0         | RTO_BACK_INT_EN<br>Response Timeout/Boot ACK Received Interrupt Enable |
| 7              | R/W        | 0x0         | DCE_INT_EN<br>Data CRC Error Interrupt Enable                          |
| 6              | R/W        | 0x0         | RCE_INT_EN<br>Response CRC Error Interrupt Enable                      |
| 5              | R/W        | 0x0         | DRR_INT_EN<br>Data Receive Request Interrupt Enable                    |
| 4              | R/W        | 0x0         | DTR_INT_EN<br>Data Transmit Request Interrupt Enable                   |
| 3              | R/W        | 0x0         | DTC_INT_EN<br>Data Transfer Complete Interrupt Enable                  |
| 2              | R/W        | 0x0         | CC_INT_EN<br>Command Complete Interrupt Enable                         |
| 1              | R/W        | 0x0         | RE_INT_EN<br>Response Error Interrupt Enable                           |
| 0              | /          | /           | /                                                                      |

### 3.3.6.14 0x0034 SMHC Masked Interrupt Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0034 |            |             | Register Name: SMHC_MINTSTS                                                                                                                                                                                                                  |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                  |
| 31             | R          | 0x0         | M_CARD_REMOVAL_INT<br>Card Removed                                                                                                                                                                                                           |
| 30             | R          | 0x0         | M_CARD_INSERT<br>Card Inserted                                                                                                                                                                                                               |
| 29:18          | /          | /           | /                                                                                                                                                                                                                                            |
| 17             | R          | 0x0         | R1B_BUSY_CLR_INT                                                                                                                                                                                                                             |
| 16             | R          | 0x0         | M_SDIO_INT<br>SDIO Interrupt                                                                                                                                                                                                                 |
| 15             | R          | 0x0         | M_DEE_INT<br>Data End-bit Error<br>When set during receiving data, it means that host controller does not receive valid data end bit.<br>When set during transmitting data, it means that host controller does not receive CRC status token. |
| 14             | R          | 0x0         | M_ACD_INT<br>Auto Command Done                                                                                                                                                                                                               |

| Offset: 0x0034 |            |             | Register Name: SMHC_MINTSTS                                                                                                                                                                                                             |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                             |
|                |            |             | When set, it means auto stop command(CMD12) completed.                                                                                                                                                                                  |
| 13             | R          | 0x0         | M_DSE_BC_INT<br>Data Start Error/busy clear<br>When set during receiving data, it means that host controller found an error start bit.<br>When set during transmitting data, it means that busy signal is cleared after the last block. |
| 12             | R          | 0x0         | M_CB_IW_INT<br>Command Busy and Illegal Write                                                                                                                                                                                           |
| 11             | R          | 0x0         | M_FU_FO_INT<br>FIFO Underrun/Overflow                                                                                                                                                                                                   |
| 10             | R          | 0x0         | M_DSTO_VSD_INT<br>Data Starvation Timeout/V1.8 Switch Done                                                                                                                                                                              |
| 9              | R          | 0x0         | M.DTO_BDS_INT<br>Data Timeout/Boot Data Start                                                                                                                                                                                           |
| 8              | R          | 0x0         | M.RTO_BACK_INT<br>Response Timeout/Boot ACK Received                                                                                                                                                                                    |
| 7              | R          | 0x0         | M.DCE_INT<br>Data CRC Error<br>When set during receiving data, it means that the received data have data CRC error.<br>When set during transmitting data, it means that the received CRC status token is negative.                      |
| 6              | R          | 0x0         | M.RCE_INT<br>Response CRC Error                                                                                                                                                                                                         |
| 5              | R          | 0x0         | M.DRR_INT<br>Data Receive Request<br>When set, it means that there are enough data in FIFO during receiving data.                                                                                                                       |
| 4              | R          | 0x0         | M.DTR_INT<br>Data Transmit Request<br>When set, it means that there are enough space in FIFO during transmitting data.                                                                                                                  |
| 3              | R          | 0x0         | M.DTC_INT<br>Data Transfer Complete                                                                                                                                                                                                     |
| 2              | R          | 0x0         | M.CC_INT<br>Command Complete                                                                                                                                                                                                            |
| 1              | R          | 0x0         | M.RE_INT<br>Response Error<br>When set, Transmit Bit error or End Bit error or CMD                                                                                                                                                      |

| Offset: 0x0034 |            |             | Register Name: SMHC_MINTSTS |
|----------------|------------|-------------|-----------------------------|
| Bit            | Read/Write | Default/Hex | Description                 |
|                |            |             | Index error may occurs.     |
| 0              | /          | /           | /                           |

### 3.3.6.15 0x0038 SMHC Raw Interrupt Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0038 |            |             | Register Name: SMHC_RINTSTS                                                                                                                                                                                                                                                                                                             |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                             |
| 31             | R/W1C      | 0x0         | CARD_REMOVAL<br>Card Removed<br>This is write-1-to-clear bits.                                                                                                                                                                                                                                                                          |
| 30             | R/W1C      | 0x0         | CARD_INSERT<br>Card Inserted<br>This is write-1-to-clear bits.                                                                                                                                                                                                                                                                          |
| 29:18          | /          | /           | /                                                                                                                                                                                                                                                                                                                                       |
| 17             | R/W1C      | 0x0         | R1B_BUSY_CLR<br>R1b busy clear<br>When set, it means that the r1b busy has finished or not set.                                                                                                                                                                                                                                         |
| 16             | R/W1C      | 0x0         | SDIOI_INT<br>SDIO Interrupt<br>This is write-1-to-clear bits.                                                                                                                                                                                                                                                                           |
| 15             | R/W1C      | 0x0         | DEE<br>Data End-bit Error<br>When set during receiving data, it means that host controller does not receive valid data end bit.<br>When set during transmitting data, it means that host controller does not receive CRC status token.<br>This is write-1-to-clear bits.                                                                |
| 14             | R/W1C      | 0x0         | ACD<br>Auto Command Done<br>When set, it means auto stop command(CMD12) completed.<br>This is write-1-to-clear bits.                                                                                                                                                                                                                    |
| 13             | R/W1C      | 0x0         | DSE_BC<br>Data Start Error/busy clear<br>When set during receiving data, it means that host controller found an error start bit. It is valid at 4-bit or 8-bit bus mode, when it set, host found start bit at data0, but not find start bit at some or all of the other data lines.<br>When set during transmitting data, it means that |

| Offset: 0x0038 |            |             | Register Name: SMHC_RINTSTS                                                                                                                                                                                                                    |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                    |
|                |            |             | busy signal is cleared after the last block.<br>This is write-1-to-clear bits.                                                                                                                                                                 |
| 12             | R/W1C      | 0x0         | CB_IW<br>Command Busy and Illegal Write<br>This is write-1-to-clear bits.                                                                                                                                                                      |
| 11             | R/W1C      | 0x0         | FU_FO<br>FIFO Underrun/Overflow<br>This is write-1-to-clear bits.                                                                                                                                                                              |
| 10             | R/W1C      | 0x0         | DSTO_VSD<br>Data Starvation Timeout/V1.8 Switch Done<br>This is write-1-to-clear bits.                                                                                                                                                         |
| 9              | R/W1C      | 0x0         | DTO_BDS<br>Data Timeout/Boot Data Start<br>When set during receiving data, it means host did not find start bit on data0(1-bit bus) or data0-data3(4-bit bus) or data0-data7(8-bit bus).<br>This is write-1-to-clear bits.                     |
| 8              | R/W1C      | 0x0         | RTO_BACK<br>Response Timeout/Boot ACK Received<br>This is write-1-to-clear bits.                                                                                                                                                               |
| 7              | R/W1C      | 0x0         | DCE<br>Data CRC Error<br>When set during receiving data, it means that the received data have data CRC error.<br>When set during transmitting data, it means that the received CRC status token is negative.<br>This is write-1-to-clear bits. |
| 6              | R/W1C      | 0x0         | RCE<br>Response CRC Error<br>This is write-1-to-clear bits.                                                                                                                                                                                    |
| 5              | R/W1C      | 0x0         | DRR<br>Data Receive Request<br>When set, it means that there are enough data in FIFO during receiving data.<br>This is write-1-to-clear bits.                                                                                                  |
| 4              | R/W1C      | 0x0         | DTR<br>Data Transmit Request<br>When set, it means that there is enough space in FIFO during transmitting data.<br>This is write-1-to-clear bits.                                                                                              |
| 3              | R/W1C      | 0x0         | DTC                                                                                                                                                                                                                                            |

| Offset: 0x0038 |            |             | Register Name: SMHC_RINTSTS                                                                                                              |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                              |
|                |            |             | Data Transfer Complete<br>This is write-1-to-clear bits.                                                                                 |
| 2              | R/W1C      | 0x0         | CC<br>Command Complete<br>When set, it means that current command completes even through error occurs.<br>This is write-1-to-clear bits. |
| 1              | R/W1C      | 0x0         | RE<br>Response Error<br>When set, Transmit Bit error or End Bit error or CMD Index error may occur.<br>This is write-1-to-clear bits.    |
| 0              | /          | /           | /                                                                                                                                        |

### 3.3.6.16 0x003C SMHC Status Register (Default Value: 0x0000\_0006)

| Offset: 0x003C |            |             | Register Name: SMHC_STATUS                                                                                  |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                 |
| 31             | R          | 0x0         | DMA_REQ<br>DMA Request<br>DMA request signal state                                                          |
| 30:28          | /          | /           | /                                                                                                           |
| 27:17          | R          | 0x0         | FIFO_LEVEL<br>FIFO Level<br>Number of filled locations in FIFO                                              |
| 16:11          | R          | 0x0         | RESP_IDX<br>Response Index<br>Index of previous response, including any auto-stop sent by controller        |
| 10             | R          | 0x0         | FSM_BUSY<br>Data FSM Busy<br>Data transmit or receive state-machine is busy                                 |
| 9              | R          | 0x0         | CARD_BUSY<br>Card data busy<br>Inverted version of DATA [0]<br>0: card data not busy<br>1: card data busy   |
| 8              | R          | 0x0         | CARD_PRESENT<br>Data [3] status<br>level of DATA [3]; checks whether card is present<br>0: card not present |

| Offset: 0x003C |            |             | Register Name: SMHC_STATUS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                |            |             | 1: card present                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 7:4            | R          | 0x0         | <p>FSM_STA<br/>                     Command FSM states:<br/>                     0000: Idle<br/>                     0001: Send INIT sequence<br/>                     0010: TX CMD start bit<br/>                     0011: TX CMD TX bit<br/>                     0100: TX CMD index + argument<br/>                     0101: TX CMD CRC7<br/>                     0110: TX CMD end bit<br/>                     0111: RX response start bit<br/>                     1000: RX response IRQ response<br/>                     1001: RX response TX bit<br/>                     1010: RX response CMD index<br/>                     1011: RX response data<br/>                     1100: RX response CRC7<br/>                     1101: RX response end bit<br/>                     1110: CMD path wait NCC<br/>                     1111: Wait; CMD-to-response turnaround</p> |
| 3              | R          | 0x0         | <p>FIFO_FULL<br/>                     FIFO full<br/>                     1: FIFO full<br/>                     0: FIFO not full</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 2              | R          | 0x1         | <p>FIFO_EMPTY<br/>                     FIFO Empty<br/>                     1: FIFO Empty<br/>                     0: FIFO not Empty</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 1              | R          | 0x1         | <p>FIFO_TX_LEVEL<br/>                     FIFO TX Water Level flag<br/>                     0: FIFO didn't reach transmit trigger level<br/>                     1: FIFO reached transmit trigger level</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 0              | R          | 0x0         | <p>FIFO_RX_LEVEL<br/>                     FIFO TX Water Level flag<br/>                     0: FIFO didn't reach receive trigger level<br/>                     1: FIFO reached receive trigger level</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

### 3.3.6.17 0x0040 SMHC FIFO Water Level Register (Default Value: 0x000F\_0000)

| Offset: 0x0040 |            |             | Register Name: SMHC_FIFOTH |
|----------------|------------|-------------|----------------------------|
| Bit            | Read/Write | Default/Hex | Description                |
| 31             | /          | /           | /                          |

| Offset: 0x0040 |            |             | Register Name: SMHC_FIFOTH                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 30:28          | R/W        | 0x0         | <p>BSIZE_OF_TRANS<br/>Burst size of multiple transaction<br/>000: 1 transfers<br/>001: 4<br/>010: 8<br/>011: 16<br/>Others: Reserved<br/>Should be programmed same as DMA controller<br/>multiple transaction size. The units for transfers are<br/>the DWORD(4Byte). A single transfer would be<br/>signaled based on this value. Value should be<br/>sub-multiple of (RX_TL + 1) and (FIFO_DEPTH -<br/>TX_TL)<br/>Recommended:<br/>BSIZE_OF_TRANS = 3, MSize = 16, TX_TL = 240, RX_TL<br/>= 15<br/>FIFO_DEPTH = 256 FIFO_SIZE = 256 * 32 = 1K</p>                                                                                                                                                                                                                                               |
| 27             | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 26:16          | R/W        | 0xF         | <p>RX_TL<br/>RX Trigger Level<br/>When BLOCK2K_EXIST is 1'b1:<br/>0x0-0x3FE: RX Trigger Level is 0-1022(Unit is equal to<br/>the FIFO_WIDTH)<br/>0x3FF reserved<br/>When BLOCK2K_EXIST is 1'b0:<br/>0x0-0xFE: RX Trigger Level is 0-254 (Unit is equal to<br/>the FIFO_WIDTH)<br/>0xFF reserved<br/>FIFO threshold when FIFO request host to receive<br/>data from FIFO. When FIFO data level is greater than<br/>this value, DMA is request is raised if DMA enabled, or<br/>RX interrupt bit is set if interrupt enabled. At the end<br/>of packet, if the last transfer is less than this level,<br/>the value is ignored and relative request will be<br/>raised as usual.<br/>When CARD_WR_THLD_ENB is set, RX_TL*4 should<br/>be less than CARD_WR_THLD.<br/>15 (means greater than 15)</p> |
| 15:11          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 10:0           | R/W        | 0x0         | TX_TL<br>TX Trigger Level                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

| Offset: 0x0040 |            |             | Register Name: SMHC_FIFOTH                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                |            |             | <p><b>When BLOCK2K_EXIST is 1'b1:</b><br/>0x1-0x3FF: TX Trigger Level is 1-1023 (Unit is equal to the FIFO_WIDTH)<br/>0x0: no trigger</p> <p><b>When BLOCK2K_EXIST is 1'b0:</b><br/>0x1-0xFF: TX Trigger Level is 1-255 (Unit is equal to the FIFO_WIDTH)<br/>0x0: no trigger</p> <p>FIFO threshold when FIFO requests host to transmit data to FIFO. When FIFO data level is less than or equal to this value, DMA TX request is raised if DMA enabled, or TX request interrupt bit is set if interrupt enabled. At the end of packet, if the last transfer is less than this level, the value is ignored and relative request will be raised as usual.</p> <p>Recommended: 240(means less than or equal to 240)</p> |

### 3.3.6.18 0x0044 SMHC FIFO Function Select Register (Default Value: 0x0000\_0000)

| Offset: 0x0044 |            |             | Register Name: SMHC_FUNS                                                                                                                                                                                                                                                                                                                                                                    |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                 |
| 31:3           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                           |
| 2              | R/W        | 0x0         | <p>ABT_RDATA<br/>Abort Read Data<br/>0: Ignored<br/>1: After suspend command is issued during read-transfer, software polls card to find when suspend happened. Once suspend occurs, software sets bit to reset data state-machine, which is waiting for next block of data.<br/>Used in SDIO card suspends sequence.<br/>This bit is auto-cleared once controller reset to idle state.</p> |
| 1              | R/W        | 0x0         | <p>READ_WAIT<br/>Read Wait<br/>0: Clear SDIO read wait<br/>1: Assert SDIO read wait</p>                                                                                                                                                                                                                                                                                                     |
| 0              | R/W        | 0x0         | <p>HOST_SEND_MMC_IRQREQ<br/>Host Send MMC IRQ Response<br/>0: Ignored<br/>1: Send auto IRQ response</p>                                                                                                                                                                                                                                                                                     |

| Offset: 0x0044 |            |             | Register Name: SMHC_FUNS                                                                                                                                                                                                                                               |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                            |
|                |            |             | <p>When host is waiting MMC card interrupt response, setting this bit will make controller cancel wait state and return to idle state, at which time, controller will receive IRQ response sent by itself.</p> <p>This bit is auto-cleared after response is sent.</p> |

### 3.3.6.19 0x0048 SMHC Transferred Byte Count Register 0 (Default Value: 0x0000\_0000)

| Offset: 0x0048 |            |             | Register Name: SMHC_TBC0                                                                                                                                                                                                      |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                   |
| 31:0           | R          | 0x0         | <p>TBC0<br/>Transferred Count 0<br/>Number of bytes transferred between card and internal FIFO.<br/>The register should be accessed in full to avoid read-coherency problems and read only after data transfer completes.</p> |

### 3.3.6.20 0x004C SMHC Transferred Byte Count Register 1 (Default Value: 0x0000\_0000)

| Offset: 0x004C |            |             | Register Name: SMHC_TBC1                                                                                                                                                                                                                 |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                              |
| 31:0           | R          | 0x0         | <p>TBC1<br/>Transferred Count 1<br/>Number of bytes transferred between Host/DMA memory and internal FIFO.<br/>The register should be accessed in full to avoid read-coherency problems and read only after data transfer completes.</p> |

### 3.3.6.21 0x0054 SMHC CRC Status Detect Control Register (Default Value: 0x0000\_0003)

| Offset: 0x0054 |            |             | Register Name: SMHC_CSDC                                                                    |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                 |
| 31:4           | /          | /           | /                                                                                           |
| 3:0            | R/W        | 0x3         | <p>CRC_DET_PARA<br/>CRC Detect Para<br/>110: HS400 speed mode<br/>011: Other speed mode</p> |

| Offset: 0x0054 |            |             | Register Name: SMHC_CSDC |
|----------------|------------|-------------|--------------------------|
| Bit            | Read/Write | Default/Hex | Description              |
|                |            |             | Others: Reserved         |

### 3.3.6.22 0x0058 SMHC Auto Command 12 Argument Register (Default Value: 0x0000\_FFFF)

| Offset: 0x0058 |            |             | Register Name: SMHC_A12A                                                                                    |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                 |
| 31:0           | R/W        | 0xFFFF      | A12A<br>Auto CMD12 Argument<br>The argument of command 12 automatically send by controller with this field. |

### 3.3.6.23 0x005C SMHC New Timing Set Register (Default Value: 0x8171\_0000)

| Offset: 0x005C |            |             | Register Name: SMHC_NTSR                                                                                                                    |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                 |
| 31             | R/W        | 0x1         | MODE_SEL<br>Mode Select<br>0: Old mode of Sample/Output Timing<br>1: New mode of Sample/Output Timing<br>Default value : 1                  |
| 30:26          | /          | /           | /                                                                                                                                           |
| 25             | R/W        | 0x0         | BOOT_DAT_RX_PHASE_CLR<br>After boot ACK, before receive boot data, clear data lines' input phase.<br>0: Disable<br>1: Enable                |
| 24             | R/W        | 0x1         | CMD_DAT_RX_PHASE_CLR<br>Clear the input phase of command lines and data lines during the update clock operation.<br>0: Disable<br>1: Enable |
| 23             | /          | /           | /                                                                                                                                           |
| 22             | R/W        | 0x1         | DAT_CRC_STATUS_RX_PHASE_CLR<br>Before receive CRC status, clear data lines' input phase.<br>0: Disable<br>1: Enable                         |
| 21             | R/W        | 0x1         | DAT_TRANS_RX_PHASE_CLR<br>Before transfer data, clear data lines' input phase.<br>0: Disable                                                |

| Offset: 0x005C |            |             | Register Name: SMHC_NTSR                                                                                                                                                                                                                            |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                         |
|                |            |             | 1: Enable                                                                                                                                                                                                                                           |
| 20             | R/W        | 0x1         | DAT_RECV_RX_PHASE_CLR<br>Before receive data, clear data lines' input phase clear<br>0: Disable<br>1: Enable                                                                                                                                        |
| 19:17          | /          | /           | /                                                                                                                                                                                                                                                   |
| 16             | R/W        | 0x1         | CMD_SEND_RX_PHASE_CLR<br>Clear command RX phase before sending the command.<br>0: Disable<br>1: Enable                                                                                                                                              |
| 15:10          | /          | /           | /                                                                                                                                                                                                                                                   |
| 9:8            | R/W        | 0x0         | DAT_SAM_TIM_PHS<br>Data Sample Timing Phase<br>00: Sample timing phase offset 90°<br>01: Sample timing phase offset 180°<br>10: Sample timing phase offset 270°<br>11: Sample timing phase offset 0° (only for SD2 hs400 mode)<br>Default value: 00 |
| 7:6            | /          | /           | /                                                                                                                                                                                                                                                   |
| 5:4            | R/W        | 0x0         | CMD_SAM_TIM_PHS<br>Command Sample Timing Phase<br>00: Sample timing phase offset 90°<br>01: Sample timing phase offset 180°<br>10: Sample timing phase offset 270°<br>11: Ignore<br>Default value: 00                                               |
| 3:1            | /          | /           | /                                                                                                                                                                                                                                                   |
| 0              | R/W        | 0x0         | HS400_NEW_SAM_EN<br>HS400 New Sample Enable<br>1: enable hs400 new sample method<br>0: disable hs400 new sample method                                                                                                                              |

### 3.3.6.24 0x0078 SMHC Hardware Reset Register (Default Value: 0x0000\_0001)

| Offset: 0x0078 |            |             | Register Name: SMHC_HWRST |
|----------------|------------|-------------|---------------------------|
| Bit            | Read/Write | Default/Hex | Description               |
| 31:1           | /          | /           | /                         |

| Offset: 0x0078 |            |             | Register Name: SMHC_HWRST                                                                                                                                          |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                        |
| 0              | R/W        | 0x1         | <p>HW_RST<br/>Hardware Reset<br/>1: Active mode<br/>0: Reset<br/>These bits cause the cards to enter pre-idle state, which requires them to be re-initialized.</p> |

### 3.3.6.25 0x0080 SMHC IDMAC Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0080 |            |             | Register Name: SMHC_IDMAC                                                                                                                                                                                                                                                                       |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                     |
| 31             | W          | 0x0         | <p>DES_LOAD_CTRL<br/>When IDMAC fetches a descriptor, if the valid bit of a descriptor is not set, IDMAC FSM will go to the suspend state. Setting this bit will make IDMAC re-fetch descriptor again and do the transfer normally.</p>                                                         |
| 30:8           | /          | /           | /                                                                                                                                                                                                                                                                                               |
| 7              | R/W        | 0x0         | <p>IDMAC_ENB<br/>IDMAC Enable.<br/>When set, the IDMAC is enabled. DE is read/write.</p>                                                                                                                                                                                                        |
| 6:2            | /          | /           | /                                                                                                                                                                                                                                                                                               |
| 1              | R/W        | 0x0         | <p>FIX_BUST_CTRL<br/>Fixed Burst.<br/>Controls whether the AHB Master interface performs fixed burst transfers or not. When set, the AHB will use only SINGLE, INCR4, INCR8 during start of normal burst transfers. When reset, the AHB will use SINGLE and INCR burst transfer operations.</p> |
| 0              | R/W        | 0x0         | <p>IDMAC_RST<br/>DMA Reset.<br/>When set, the DMA Controller resets all its internal registers. SWR is read/write. It is automatically cleared after 1 clock cycle.</p>                                                                                                                         |

### 3.3.6.26 0x0084 SMHC Descriptor List Base Address Register (Default Value: 0x0000\_0000)

| Offset: 0x0084 |            |             | Register Name: SMHC_DLBA |
|----------------|------------|-------------|--------------------------|
| Bit            | Read/Write | Default/Hex | Description              |
| 31:0           | R/W        | 0x0         | DES_BASE_ADDR            |

| Offset: 0x0084 |            |             | Register Name: SMHC_DLBA                                                                                 |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                              |
|                |            |             | Start of Descriptor List.<br>Contains the base address of the First Descriptor, is a word(4byte) address |

### 3.3.6.27 0x0088 SMHC IDMAC Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0088 |            |             | Register Name: SMHC_IDST                                                                                                                                                                                                                                                                                                                                                                           |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                        |
| 31:13          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                  |
| 12:10          | R          | 0x0         | IDMAC_ERR_STA<br>Error Bits.<br>Indicates the type of error that caused a Bus Error.<br>Valid only with Fatal Bus Error bit (SMHC_IDST [2]) set. This field does not generate an interrupt.<br>001: Host Abort received during transmission<br>010: Host Abort received during reception<br>Others: Reserved<br>This bit is read-only.                                                             |
| 9              | R/W1C      | 0x0         | AIS<br>Abnormal Interrupt Summary.<br>Logical OR of the following:<br>SMHC_IDST [2]: Fatal Bus Interrupt<br>SMHC_IDST [4]: Descriptor unavailable bit Interrupt<br>SMHC_IDST [5]: Card Error Summary Interrupt<br>Only unmasked bits affect this bit.<br>This is a sticky bit and must be cleared each time a corresponding bit that causes AIS to be set is cleared. Writing a 1 clears this bit. |
| 8              | R/W1C      | 0x0         | NIS<br>Normal Interrupt Summary.<br>Logical OR of the following:<br>SMHC_IDST [0]: Transmit Interrupt<br>SMHC_IDST [1]: Receive Interrupt<br>Only unmasked bits affect this bit.<br>This is a sticky bit and must be cleared each time a corresponding bit that causes NIS to be set is cleared. Writing a 1 clears this bit.                                                                      |
| 7:6            | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                  |
| 5              | R/W1C      | 0x0         | ERR_FLAG_SUM<br>Card Error Summary.<br>Indicates the status of the transaction to/from the                                                                                                                                                                                                                                                                                                         |

| Offset: 0x0088 |            |             | Register Name: SMHC_IDST                                                                                                                                                                                                                                                                   |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                |
|                |            |             | card; also present in RINTSTS. Indicates the logical OR of the following bits:<br>EBE: End Bit Error<br>RTO: Response Timeout<br>RCRC: Response CRC<br>SBE: Start Bit Error<br>DRTO: Data Read Timeout<br>DCRC: Data CRC for Receive<br>RE: Response Error<br>Writing a 1 clears this bit. |
| 4              | R/W1C      | 0x0         | DES_UNAVL_INT<br>Descriptor Unavailable Interrupt.<br>This bit is set when the descriptor is unavailable due to OWN bit = 0 (DES0[31] =0).<br>Writing a 1 clears this bit.                                                                                                                 |
| 3              | /          | /           | /                                                                                                                                                                                                                                                                                          |
| 2              | R/W1C      | 0x0         | FATAL_BERR_INT<br>Fatal Bus Error Interrupt.<br>Indicates that a Bus Error occurred (SMHC_IDST [12:10]). When this bit is set, the DMA disables all its bus accesses.<br>Writing a 1 clears this bit.                                                                                      |
| 1              | R/W1C      | 0x0         | RX_INT<br>Receive Interrupt.<br>Indicates the completion of data reception for a descriptor.<br>Writing a 1 clears this bit.                                                                                                                                                               |
| 0              | R/W1C      | 0x0         | TX_INT<br>Transmit Interrupt.<br>Indicates that data transmission is finished for a descriptor. Writing a 1 clears this bit.                                                                                                                                                               |

### 3.3.6.28 0x008C SMHC IDMAC Interrupt Enable Register (Default Value: 0x0000\_0000)

| Offset: 0x008C |            |             | Register Name: SMHC_IDIE                                                                                    |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                 |
| 31:6           | /          | /           | /                                                                                                           |
| 5              | R/W        | 0x0         | ERR_SUM_INT_ENB<br>Card Error Summary Interrupt Enable.<br>When set, it enables the Card Interrupt summary. |
| 4              | R/W        | 0x0         | DES_UNAVL_INT_ENB                                                                                           |

| Offset: 0x008C |            |             | Register Name: SMHC_IDIE                                                                                                                                                                        |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                     |
|                |            |             | Descriptor Unavailable Interrupt.<br>When set along with Abnormal Interrupt Summary Enable, the Descriptor Unavailable interrupt is enabled.                                                    |
| 3              | /          | /           | /                                                                                                                                                                                               |
| 2              | R/W        | 0x0         | FERR_INT_ENB<br>Fatal Bus Error Enable.<br>When set with Abnormal Interrupt Summary Enable, the Fatal Bus Error Interrupt is enabled. When reset, Fatal Bus Error Enable Interrupt is disabled. |
| 1              | R/W        | 0x0         | RX_INT_ENB<br>Receive Interrupt Enable.<br>When set, Normal Interrupt Summary Enable, Receive Interrupt is enabled. When reset, Receive Interrupt is disabled.                                  |
| 0              | R/W        | 0x0         | TX_INT_ENB<br>Transmit Interrupt Enable.<br>When set, Normal Interrupt Summary Enable, Transmit Interrupt is enabled. When reset, Transmit Interrupt is disabled.                               |

### 3.3.6.29 0x0100 SMHC Card Threshold Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0100 |            |             | Register Name: SMHC_THLD                                                                                                                                                                                                                                                            |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                         |
| 31:29          | /          | /           | /                                                                                                                                                                                                                                                                                   |
| 28:16          | R/W        | 0x0         | CARD_WR_THLD<br>Card Read/write Threshold Size (Unit: byte)                                                                                                                                                                                                                         |
| 15:3           | /          | /           | /                                                                                                                                                                                                                                                                                   |
| 2              | R/W        | 0x0         | CARD_WR_THLD_ENB<br>Card Write Threshold Enable<br>0: Card write threshold disable<br>1: Card write threshold enabled<br>Host controller initiates write transfer only if card threshold amount of data is available in transmit FIFO.<br><b>Note: Not support DDR 8-wire mode.</b> |
| 1              | R/W        | 0x0         | BCIG<br>Busy Clear Interrupt Generation<br>0: Busy Clear Interrupt disabled<br>1: Busy Clear Interrupt Enabled                                                                                                                                                                      |

| Offset: 0x0100 |            |             | Register Name: SMHC_THLD                                                                                                                                                                                                       |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                    |
|                |            |             | The application can disable this feature if it does not want to wait for a Busy Clear Interrupt.                                                                                                                               |
| 0              | R/W        | 0x0         | CARD_RD_THLD_ENB<br>Card Read Threshold Enable<br>0: Card Read Threshold Disable<br>1: Card Read Threshold Enable<br>Host controller initiates Read Transfer only if CARD_RD_THLD amount of space is available in receive FIFO |

### 3.3.6.30 0x0104 SMHC Sample FIFO Control Register (Default Value: 0x0000\_0006)

| Offset: 0x0104 |            |             | Register Name: SMHC_SFC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 31:5           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 4:1            | R/W        | 0x3         | STOP_CLK_CTRL<br>Stop Clock Control<br>When receiving data, if CARD_RD_THLD_ENB is set and CARD_RD_THLD is set same with BLK_SZ, the device clock may stop at block gap during data receiving.<br>This field is used to control the position of stopping clock.<br>The value can be change between 0x0 and 0xF, but actually the available value and the position of stopping clock must be decided by the actual situation.<br>The value increase one in this field is linked to one cycle(two cycle in DDR mode) that the position of stopping clock moved up. |
| 0              | R/W        | 0x0         | BYPASS_EN<br>Bypass enable<br>When set, sample FIFO will be bypassed.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

### 3.3.6.31 0x0108 SMHC Auto Command 23 Argument Register (Default Value: 0x0000\_0000)

| Offset: 0x0108 |            |             | Register Name: SMHC_A23A    |
|----------------|------------|-------------|-----------------------------|
| Bit            | Read/Write | Default/Hex | Description                 |
| 31:0           | R/W        | 0x0         | A23A<br>Auto CMD23 Argument |

| Offset: 0x0108 |            |             | Register Name: SMHC_A23A                                                        |
|----------------|------------|-------------|---------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                     |
|                |            |             | The argument of command 23 is automatically sent by controller with this field. |

### 3.3.6.32 0x010C SMHC eMMC4.5 DDR Start Bit Detection Control Register (Default Value: 0x0000\_0000)

| Offset: 0x010C |            |             | Register Name: EMMC_DDR_SBIT_DET                                                                                                                                                                                                                                                    |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                         |
| 31             | R/W        | 0x0         | HS400_MD_EN<br>HS400 Mode Enable<br>0: Disable<br>1: Enable<br>It is required to set this bit to '1' before initiating any data transfer CMD in HS400 mode.                                                                                                                         |
| 30:1           | /          | /           | /                                                                                                                                                                                                                                                                                   |
| 0              | R/W        | 0x0         | HALF_START_BIT<br>Control for start bit detection mechanism inside host controller based on duration of start bit.<br>For eMMC 4.5, start bit can be:<br>0: Full cycle<br>1: Less than one full cycle<br>Set HALF_START_BIT=1 for eMMC 4.5 and above; set to 0 for SD applications. |

### 3.3.6.33 0x0138 SMHC Extended Command Register (Default Value: 0x0000\_0000)

| Offset: 0x0138 |            |             | Register Name: SMHC_EXT_CMD                                                                                                                                                                    |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                    |
| 31:1           | /          | /           | /                                                                                                                                                                                              |
| 0              | R/W        | 0x0         | AUTO_CMD23_EN<br>Send CMD23 Automatically<br>When set this bit, send CMD23 automatically before send command specified in SMHC_CMD register.<br>When SOFT_RST set, this field will be cleared. |

### 3.3.6.34 0x013C SMHC Extended Response Register (Default Value: 0x0000\_0000)

| Offset: 0x013C |            |             | Register Name: SMHC_EXT_RESP |
|----------------|------------|-------------|------------------------------|
| Bit            | Read/Write | Default/Hex | Description                  |

| Offset: 0x013C |            |             | Register Name: SMHC_EXT RESP                                                            |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                             |
| 31:0           | R          | 0x0         | SMHC_EXT RESP<br>When AUTO_CMD23_EN is set, this register stores the response of CMD23. |

### 3.3.6.35 0x0140 SMHC Drive Delay Control Register (Default Value: 0x0001\_0000)

| Offset: 0x0140 |            |             | Register Name: SMHC_DRV_DL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 31:18          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 17             | R/W        | 0x0         | DAT_DRV_PH_SEL<br>Data Drive Phase Select<br>0: Data drive phase offset is:<br>90° at SDR mode,<br>45° at DDR8 mode,<br>90° at DDR4 mode when 0x5C [31] is low,<br>45° at DDR4 mode when 0x5C [31] is high,<br>90° at HS400 mode when 0x5C [0] is low,<br>45° at HS400 mode when 0x5C [0] is high.<br>1: Data drive phase offset is:<br>180° at SDR mode,<br>90° at DDR8 mode,<br>180° at DDR4 mode when 0x5C [31] is low,<br>90° at DDR4 mode when 0x5C [31] is high,<br>180° at HS400 mode when 0x5C [0] is low,<br>90° at HS400 mode when 0x5C[0] is high. |
| 16             | R/W        | 0x1         | CMD_DRV_PH_SEL<br>Command Drive Phase Select<br>0: Command drive phase offset is:<br>90° at SDR mode,<br>45° at DDR8 mode,<br>90° at DDR4 mode when 0x5C [31] is low,<br>45° at DDR4 mode when 0x5C [31] is high,<br>90° at HS400 mode<br>1: Command drive phase offset is:<br>180° at SDR mode,<br>90° at DDR8 mode,<br>180° at DDR4 mode when 0x5C [31] is low,<br>90° at DDR4 mode when 0x5C [31] is high,<br>180° at HS400 mode.                                                                                                                          |
| 15:0           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

## 3.3.6.36 0x0144 SMHC Sample Delay Control Register (Default Value: 0x0000\_2000)

| Offset: 0x0144 |            |             | Register Name: SMHC_SAMP_DL                                                                                                                                                                                                                                                                                                                      |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                      |
| 31:16          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                |
| 15             | R/W        | 0x0         | SAMP_DL_CAL_START<br>Sample Delay Calibration Start<br>When set, start sample delay chain calibration.                                                                                                                                                                                                                                           |
| 14             | R          | 0x0         | SAMP_DL_CAL_DONE<br>Sample Delay Calibration Done<br>When set, it means that sample delay chain calibration is done and the result of calibration is shown in SAMP_DL.                                                                                                                                                                           |
| 13:8           | R          | 0x20        | SAMP_DL<br>Sample Delay<br>It indicates the number of delay cells corresponding to current card clock. The delay time generated by these delay cells is equal to the cycle of card clock nearly.<br>Generally, it is necessary to do drive delay calibration when card clock is changed.<br>This bit is valid only when SAMP_DL_CAL_DONE is set. |
| 7              | R/W        | 0x0         | SAMP_DL_SW_EN<br>Sample Delay Software Enable<br>When set, enable sample delay specified at SAMP_DL_SW                                                                                                                                                                                                                                           |
| 6              | /          | /           | /                                                                                                                                                                                                                                                                                                                                                |
| 5:0            | R/W        | 0x0         | SAMP_DL_SW<br>Sample Delay Software<br>The relative delay between clock line and command line, data lines.<br>It can be determined according to the value of SAMP_DL, the cycle of card clock and device's input timing requirement.                                                                                                             |

## 3.3.6.37 0x0148 SMHC Data Strobe Delay Control Register (Default Value: 0x0000\_2000)

| Offset: 0x0148 |            |             | Register Name: SMHC_DS_DL |
|----------------|------------|-------------|---------------------------|
| Bit            | Read/Write | Default/Hex | Description               |
| 31:16          | /          | /           | /                         |

| Offset: 0x0148 |            |             | Register Name: SMHC_DS_DL                                                                                                                                                                                                                                     |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                   |
| 15             | R/W        | 0x0         | DS_DL_CAL_START<br>Data Strobe Delay Calibration Start<br>When set, start sample delay chain calibration.                                                                                                                                                     |
| 14             | R          | 0x0         | DS_DL_CAL_DONE<br>Data Strobe Delay Calibration Done<br>When set, it means that sample delay chain calibration is done and the result of calibration is shown in DS_DL.                                                                                       |
| 13:8           | R          | 0x20        | DS_DL<br>Data Strobe Delay<br>It indicates the number of delay cells corresponding to current card clock. The delay time generated by these delay cells is equal to the cycle of SMHC's clock nearly.<br>This bit is valid only when SAMP_DL_CAL_DONE is set. |
| 7              | R/W        | 0x0         | DS_DL_SW_EN<br>Sample Delay Software Enable                                                                                                                                                                                                                   |
| 6              | /          | /           | /                                                                                                                                                                                                                                                             |
| 5:0            | R/W        | 0x0         | DS_DL_SW<br>Data Strobe Delay Software                                                                                                                                                                                                                        |

### 3.3.6.38 0x014C SMHC HS400 New Timing Delay Control Register (Default Value: 0x0000\_0800)

| Offset: 0x014C |            |             | Register Name: SMHC_HS400_DL                                                                                                                                            |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                             |
| 31:16          | /          | /           | /                                                                                                                                                                       |
| 15             | R/W        | 0x0         | HS400_DL_CAL_START<br>HS400 Delay Calibration Start<br>When set, start sample delay chain calibration.                                                                  |
| 14             | R          | 0x0         | HS400_DL_CAL_DONE<br>HS400 Delay Calibration Done<br>When set, it means that sample delay chain calibration is done and the result of calibration is shown in HS400_DL. |
| 13:12          | /          | /           | /                                                                                                                                                                       |
| 11:8           | R          | 0x8         | HS400_DL<br>HS400 Delay<br>It indicates the number of delay cells corresponding to current card clock. The delay                                                        |

| Offset: 0x014C |            |             | Register Name: SMHC_HS400_DL                                                                                                               |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                |
|                |            |             | time generated by these delay cells is equal to the cycle of SMHC's clock nearly.<br>This bit is valid only when HS400_DL_CAL_DONE is set. |
| 7              | R/W        | 0x0         | HS400_DL_SW_EN<br>Sample Delay Software Enable                                                                                             |
| 6:4            | /          | /           | /                                                                                                                                          |
| 3:0            | R/W        | 0x0         | HS400_DL_SW<br>HS400 Delay Software                                                                                                        |

### 3.3.6.39 0x0154 SMHC Card interface counter Register (Default Value:0x0)

| Offset: 0x0154 |            |             | Register Name: SMHC_CIU_CNT                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 31:8           | R          | 0x0         | DATA_PATH_CNT<br>Data Path Counter<br>This field indicates the count value of counters for each stage when host read or write data.<br>When Host read data, this field is one of the following values:<br>1. The time of wait data start bit<br>2. The byte count of receive data<br>3. The count of receive crc16<br>When Host write data, this field is one of the following values:<br>1. The byte count of transmit data<br>2. The count of transmit crc16<br>3. The time of wait receive CRC status |
| 7:0            | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

### 3.3.6.40 0x0200 SMHC FIFO Register (Default Value: 0x0000\_0000)

| Offset: 0x0200 |            |             | Register Name: SMHC_FIFO |
|----------------|------------|-------------|--------------------------|
| Bit            | Read/Write | Default/Hex | Description              |
| 31:0           | R/W        | 0x0         | TX/RX_FIFO<br>Data FIFO  |

### 3.3.6.41 0x0408 CQCFG Command Queuing Configuration Register (Default Value: 0x0200\_0000)

This register controls CQE behavior affecting the general operation of command queuing module or operation of multiple tasks in the same time.

| Offset: 0x0408 |            |             | Register Name: CQCFG                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 31:16          | R/W        | 0x200       | CQE_BLOCK_SIZE<br>CQE Block Size Configuration<br>It must be 0x200 when CMDQ_MODE is CMDQ or CMDQ_HALF or CMDQ_ALMOST.                                                                                                                                                                                                                                                                                                                                                            |
| 15:13          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 12             | R/W        | 0x0         | CQE_DCMD_EN<br>Direct Command (DCMD) Enable<br>This bit indicates to the hardware whether the Task Descriptor in slot #31 of the TDL is a Data Transfer Task Descriptor, or a Direct Command Task Descriptor.<br>CQE uses this bit when a task is issued in slot #31, to determine how to decode the Task Descriptor.<br>Bit Value Description<br>1 = Task descriptor in slot #31 is a DCMD Task Descriptor<br>0 = Task descriptor in slot #31 is a Data Transfer Task Descriptor |
| 11:9           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 8              | R/W        | 0x0         | CQE_TASK_DESC_SIZE<br>Task Descriptor Size<br>This bit indicates whether the task descriptor size is 128 bits or 64 bits as detailed in Data Structures section. This bit can only be configured when Command Queuing Enable bit is '0' (command queuing is disabled)<br>Bit Value Description<br>1 = Task descriptor size is 128 bits<br>0 = Task descriptor size is 64 bits                                                                                                     |
| 7:6            | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 5:4            | R/W        | 0x0         | CMDQ_MODE<br>Command Queue Mode select<br>This field is used to select CMDQ mode, there are four kinds of CMDQ mode: <ul style="list-style-type: none"><li>• CMDQ_HALF mode<br/>CMD and data can't be transmitted at the same time, but the current task can be sent to the device before the previous task is completed.</li></ul>                                                                                                                                               |

| Offset: 0x0408 |            |             | Register Name: CQCFG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                |            |             | <ul style="list-style-type: none"> <li>CMDQ_ALMOST mode<br/>CMD can be sent at the start of block, and the current task can be sent to the device before the previous task is completed.</li> </ul> <p>The Field Value Description<br/>2'b00: Reserved<br/>2'b01: CMDQ_HALF mode<br/>2'b10: CMDQ_ALMOST mode (Not support DDR 8-wire mode)<br/>2'b11: Reserved</p> <p><b>Note:</b> The CARD_WR_THLD_ENB must be set and the value of CARD_WR_THLD must be greater than or equal CQE_BLOCK_SIZE when CQE_MODE is CMDQ_ALMOST.</p>                                               |
| 3:1            | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 0              | R/W        | 0x0         | <p>CQE_EN<br/>Command Queuing Enable<br/>Software shall write '1' this bit when in order to enable command queuing mode (i.e., enable CQE).<br/>When this bit is 0, CQE is disabled and software controls the eMMC bus using the legacy eMMC host controller.</p> <p>Before software writes '1' to this bit, software shall verify that the eMMC host controller is in idle state and there are no commands or data transfers ongoing.<br/>When software wants to exit command queuing mode, it shall clear all previous tasks if such exist before setting this bit to 0.</p> |

### 3.3.6.42 0x040C CQCTL Command Queuing Control Register (Default Value: 0x0000\_0000)

This register controls CQE behavior affecting the general operation of command queuing module or operation of multiple tasks in the same time.

| Offset: 0x040C |            |             | Register Name: CQCTL                                                                                                                                            |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                     |
| 31:9           | /          | /           | /                                                                                                                                                               |
| 8              | R/WAC      | 0x0         | <p>CQE_TCL_ALL<br/>CQE Task Cleared All<br/>Software shall write '1' this bit when it wants to clear all the tasks sent to the device. This bit can only be</p> |

| Offset: 0x040C |            |             | Register Name: CQCTL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                |            |             | <p>written when CQE is in halt state (i.e., Halt bit is 1). When software writes 1, the value of the register is updated to '1', and CQE shall reset CQTDBR register and all other context information for all unfinished tasks. Then CQE will clear this bit.</p> <p>Software should poll on this bit until it is set to back 0 and may then resume normal operation, by clearing the Halt bit.</p> <p>CQE does not communicate to the device that the tasks were cleared. It is software's responsibility to order the device to discard the tasks in its queue using CMDQ_TASK_MGMT command.</p> <p>Writing '0' to this register shall have no effect.</p>                                                                                                                                                |
| 7:1            | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 0              | R/W        | 0x0         | <p><b>CQE_HALT</b></p> <p>Host software shall write '1' to the bit when it wants to acquire software control over the eMMC bus and disable CQE from issuing commands on the bus.</p> <p>For example, issuing a Discard Task command (CMDQ_TASK_MGMT)</p> <p>When software writes '1', CQE shall complete the ongoing task if such a task is in progress.</p> <p>Once the task is completed and CQE is in idle state, CQE shall not issue new commands and shall indicate so to software by setting this bit to 1.</p> <p>Software may poll on this bit until it is set to 1, and may only then send commands on the eMMC bus.</p> <p>In order to exit halt state (i.e., resume CQE activity), software shall clear this bit (write '0'). Writing '0' when the value is already '0' shall have no effect.</p> |

### 3.3.6.43 0x0410 CQIS Command Queuing Interrupt Status Register (Default Value: 0x0000\_0000)

This register indicates pending interrupts that require service. Each bit in this registers is asserted in response a specific event, only if the respective bit is set in CQISTE register.

| Offset: 0x0410 |            |             | Register Name: CQIS      |
|----------------|------------|-------------|--------------------------|
| Bit            | Read/Write | Default/Hex | Description              |
| 31:4           | /          | /           | /                        |
| 3              | R/W1C      | 0x0         | CQIS_TCL<br>Task Cleared |

| Offset: 0x0410 |            |             | Register Name: CQIS                                                                                                                                                                                                                                                                                       |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                               |
|                |            |             | This status bit is asserted (if CQISTE.TCL=1) when a task clear operation is completed by CQE. The completed task clear operation is either an individual task clear (CQTCLR) or clearing of all tasks (CQCTL).                                                                                           |
| 2              | R/W1C      | 0x0         | CQIS_RED<br>Response Error Detected Interrupt<br>This status bit is asserted (if CQISTE.RED=1) when a response is received with an error bit set in the device status field.<br>Software uses CQRMEM register to configure which device status bit fields may trigger an interrupt, and which are masked. |
| 1              | R/W1C      | 0x0         | CQIS_TCC<br>Task Complete Interrupt<br>This status bit is asserted (if CQISTE.TCC=1) when at least one of the following two conditions are met:<br>A task is completed and the INT bit is set in its Task Descriptor<br>Interrupt caused by Interrupt Coalescing logic (see <a href="#">0</a> )           |
| 0              | R/W1C      | 0x0         | CQIS_HAC<br>Halt Complete Interrupt<br>This status bit is asserted (if CQISTE.HAC=1) when halt bit in CQCTL register transitions from 0 to 1 indicating that host controller has completed its current ongoing task and has entered halt state.                                                           |

### 3.3.6.44 0x0414 CQISTE Command Queuing Interrupt Status Enable Register (Default Value: 0x0000\_0000)

This register enables and disables the reporting of the corresponding interrupt to host software in CQIS register. When a bit is set ('1') and the corresponding interrupt condition is active, then the bit in CQIS is asserted. Interrupt sources that are disabled ('0') are not indicated in the CQIS register. This register is bit-index matched to CQIS register.

| Offset: 0x0414 |            |             | Register Name: CQISTE                                                                                      |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                |
| 31:4           | /          | /           | /                                                                                                          |
| 3              | R/W        | 0x0         | CQISTE_TCL<br>Task Cleared Status Enable<br>1: CQIS.TCL will be set when its interrupt condition is active |

| Offset: 0x0414 |            |             | Register Name: CQISTE                                                                                                                            |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                      |
|                |            |             | 0: CQIS.TCL is disabled                                                                                                                          |
| 2              | R/W        | 0x0         | CQISTE_RED<br>Response Error Detected Status Enable<br>1: CQIS.RED will be set when its interrupt condition is active<br>0: CQIS.RED is disabled |
| 1              | R/W        | 0x0         | CQISTE_TCC<br>Task Complete Status Enable<br>1: CQIS.TCC will be set when its interrupt condition is active<br>0: CQIS.TCC is disabled           |
| 0              | R/W        | 0x0         | CQISTE_HAC<br>Halt Complete Status Enable<br>1: CQIS.HAC will be set when its interrupt condition is active<br>0: CQIS.HAC is disabled           |

### 3.3.6.45 0x0418 CQISGE Command Queuing Interrupt Signal Enable Register (Default Value: 0x0000\_0000)

This register enables and disables the generation of interrupts to host software. When a bit is set ('1') and the corresponding bit in CQIS is set, then an interrupt is generated. Interrupt sources that are disabled ('0') are still indicated in the CQIS register. This register is bit-index matched to CQIS register.

| Offset: 0x0418 |            |             | Register Name: CQISGE                                                                                                         |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                   |
| 31:4           | /          | /           | /                                                                                                                             |
| 3              | R/W        | 0x0         | CQISGE_TCL<br>Task Cleared Signal Enable<br>When set and CQIS.TCL is asserted, the CQE shall generate an interrupt            |
| 2              | R/W        | 0x0         | CQISGE_RED<br>Response Error Detected Signal Enable<br>When set and CQIS.RED is asserted, the CQE shall generate an interrupt |
| 1              | R/W        | 0x0         | CQISGE_TCC<br>Task Complete Signal Enable<br>When set and CQIS.TCC is asserted, the CQE shall generate an interrupt           |
| 0              | R/W        | 0x0         | CQISGE_HAC                                                                                                                    |

| Offset: 0x0418 |            |             | Register Name: CQISGE                                                                                 |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                           |
|                |            |             | Halt Complete Signal Enable<br>When set and CQIS.HAC is asserted, the CQE shall generate an interrupt |

### 3.3.6.46 0x041C CQIC Interrupt Coalescing Register (Default Value: 0x0000\_0000)

This register controls the interrupt coalescing feature.

| Offset: 0x041C |            |             | Register Name: CQIC                                                                                                                                                                                                                                                                                                                                                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                          |
| 31             | R/W        | 0x0         | CQIC_EN<br>Interrupt Coalescing Enable/Disable<br>When set to '0' by software, command responses are neither counted nor timed. Interrupts are still triggered by completion of tasks with INT=1 in the Task Descriptor.<br>When set to '1', the interrupt coalescing mechanism is enabled and coalesced interrupts are generated                                                                    |
| 30:21          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                    |
| 20             | R          | 0x0         | CQIC_SB<br>Interrupt Coalescing Status Bit<br>This bit indicates to software whether any tasks (with INT=0) have completed and counted towards interrupt coalescing (i.e., ICSB is set if and only if IC counter > 0).<br>Bit Value Description<br>1: At least one task completion has been counted (IC counter >0)<br>0: No task completions have occurred since last counter reset (IC counter =0) |
| 19:17          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                    |
| 16             | W          | 0x0         | CQIC_CTR<br>Counter and Timer Reset<br>When host driver writes '1', the interrupt coalescing timer and counter are reset                                                                                                                                                                                                                                                                             |
| 15             | W          | 0x0         | CQIC_CTH_WEN<br>Interrupt Coalescing Counter Threshold Write Enable<br>When software writes '1', the value ICCTH is updated with the contents written at the same cycle.<br>When software writes '0', the value in ICCTH is not updated.<br>Note: Write operations to ICCTH are only allowed when                                                                                                    |

| Offset: 0x041C |            |             | Register Name: CQIC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                |            |             | the task queue is empty.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 14:13          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 12:8           | R/W        | 0x0         | <p>CQIC_CTH<br/>Interrupt Coalescing Counter Threshold<br/>Software uses this field to configure the number of task completions (only tasks with INT=0 in the Task Descriptor) which are required in order to generate an interrupt.</p> <p>Counter Operation: As data transfer tasks with INT=0 complete, they are counted by CQE. The counter is reset by software during the interrupt service routine. The counter stops counting when it reaches the value configured in ICCTH. The maximum allowed value is 31</p> <p>Note:</p> <ul style="list-style-type: none"> <li>When ICCTH is 0, task completions are not counted, and counting-based interrupts are not generated.</li> <li>In order to write to this field, the ICCTHWEN bit must be set at the same write operation.</li> </ul> |
| 7              | W          | 0x0         | <p>CQIC_TOVAL_WEN<br/>Interrupt Coalescing Timeout Value Write Enable<br/>When software writes '1', the value ICTOVAL is updated with the contents written at the same cycle.<br/>When software writes '0', the value in ICTOVAL is not updated.</p> <p>Note: Write operations to ICTOVAL are only allowed when the task queue is empty.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 6:0            | R/W        | 0x0         | <p>CQIC_TOVAL<br/>Interrupt Coalescing Timeout Value<br/>Software uses this field to configure the maximum time allowed between the completion of a task on the bus and the generation of an interrupt.</p> <p>Timer Operation: The timer is reset by software during the interrupt service routine.<br/>It starts running when a data transfer task with INT=0 is completed, after the timer was reset. When the timer reaches the value configured in ICTOVAL field it generates an interrupt and stops.<br/>The timer's unit is equal to 1024 clock periods of the clock whose frequency is specified in the Internal Timer Clock Frequency field CQCAP register.</p>                                                                                                                        |

| Offset: 0x041C |            |             | Register Name: CQIC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                |            |             | <p>The minimum value is 01h (1024 clock periods) and the maximum value is 7Fh (127*1024 clock periods). For example, a CQCAP field value of 0 indicates a 19.2 MHz clock frequency (period = 52.08 ns). If the setting in ICTOVAL is 10h, the calculated polling period is <math>16*1024*52.08\text{ ns} = 853.33\text{ us}</math></p> <p>Note: When ICTOVAL is 0, the timer is not running, and timer-based interrupts are not generated.</p> <p>In order to write to this field, the ICTOVALWEN bit must be set at the same write operation.</p> |

### 3.3.6.47 0x0420 CQTDLBA Command Queuing Task Descriptor List Base Address Register (Default Value: 0x0000\_0000)

This register is used for configuring the lower 32 bits of the byte address of the head of the Task Descriptor List in the host memory.

| Offset: 0x0420 |            |             | Register Name: CQTDLBA                                                                                                                                                                                                                                                                                                                                                     |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                |
| 31:0           | R/W        | 0x0         | <p>CQE_TDLBA<br/>Task Descriptor List Base Address<br/>This register stores the LSB bits (bits 31:0) of the byte address of the head of the Task Descriptor List in system memory.<br/>The size of the task descriptor list is 32 * (Task Descriptor size + Transfer Descriptor size) as configured by Host driver.<br/>This address shall be set on 1 KByte boundary.</p> |

### 3.3.6.48 0x0428 CQTDBR Command Queuing Task Doorbell Register (Default Value: 0x0000\_0000)

Using this register, software triggers CQE to process a new task.

| Offset: 0x0428 |            |             | Register Name: CQTDBR                                                                                                                                                                                                                                  |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                            |
| 31:0           | R/W1S      | 0x0         | <p>CQE_TDBR<br/>Command Queuing Task Doorbell<br/>Software shall configure TDLBA and TDLBAU, and enable CQE in CQCFG before using this register.<br/>Writing 1 to bit n of this register triggers CQE to start processing the task encoded in slot</p> |

| Offset: 0x0428 |            |             | Register Name: CQTDBR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                |            |             | <p>n of the TDL.</p> <p>CQE always processes tasks in-order according to the order submitted to the list by CQTDBR write transactions.</p> <p>CQE processes Data Transfer tasks by reading the Task Descriptor and sending QUEUED_TASK_PARAMS (CMD44) and QUEUED_TASK_ADDRESS (CMD45) commands to the device.</p> <p>CQE processes DCMD tasks (in slot #31, when enabled) by reading the Task Descriptor, and generating the command encoded by its index and argument.</p> <p>The corresponding bit is cleared to '0' by CQE in one of the following events:</p> <ul style="list-style-type: none"> <li>When a task execution is completed (with success or error)</li> <li>The task is cleared using CQTCLR register</li> <li>All tasks are cleared using CQCTL register</li> <li>CQE is disabled using QCFCFG register</li> <li>Software may initiate multiple tasks at the same time (batch submission) by writing 1 to multiple bits of this register in the same transaction.</li> </ul> <p>In the case of batch submission:</p> <ul style="list-style-type: none"> <li>CQE shall process the tasks in order of the task index, starting with the lowest index.</li> <li>If one or more tasks in the batch are marked with QBR, the ordering of execution will be based on said processing order.</li> <li>Writing 0 by software shall have no impact on the hardware, and will not change the value of the register bit.</li> </ul> |

### 3.3.6.49 0x042C CQTCN Task Completion Notification Register (Default Value: 0x0000\_0000)

This register is used by CQE to notify software about completed tasks.

| Offset: 0x042C |            |             | Register Name: CQTCN                                                                                                                                                                                                |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                         |
| 31:0           | R/W1C      | 0x0         | <p>CQE_TCN</p> <p>Task Complete Notification</p> <p>CQE shall set bit <i>n</i> of this register (at the same time it clears bit <i>n</i> of CQTDBR) when a task execution is completed (with success or error).</p> |

| Offset: 0x042C |            |             | Register Name: CQTCN                                                                                                                                                                                                             |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                      |
|                |            |             | When receiving interrupt for task completion, software may read this register to know which tasks have finished. After reading this register, software may clear the relevant bit fields by writing 1 to the corresponding bits. |

### 3.3.6.50 0x0430 CQDQS Device Queue Status Register (Default Value: 0x0000\_0000)

This register stores the most recent value of the device's queue status.

| Offset: 0x0430 |            |             | Register Name: CQDQS                                                                                                                                                                                                    |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                             |
| 31:0           | R          | 0x0         | CQE_DQS<br>Device Queue Status<br>Every time the Host controller receives a queue status register (QSR) from the device, it updates this register with the response of status command, i.e., the device's queue status. |

### 3.3.6.51 0x0434 CQDPT Device Pending Tasks Register (Default Value: 0x0000\_0000)

This register indicates to software which tasks are queued in the device, awaiting execution.

| Offset: 0x0434 |            |            | Register Name: CQDPT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------------|------------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/He | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 31:0           | R          | 0x0        | CQE_DPT<br>Device Pending Tasks<br>Bit <i>n</i> of this register is set if and only if QUEUED_TASK_PARAMS (CMD44) and QUEUED_TASK_ADDRESS (CMD45) were sent for this specific task and if this task hasn't been executed yet. CQE shall set this bit after receiving a successful response for CMD45. CQE shall clear this bit after the task has completed execution.<br>Software needs to read this register in the task-discard procedure, when the controller is halted, to determine if the task is queued in the device. If the task is queued, the driver sends a CMDQ_TASK_MGMT (CMD48) to the device ordering it to discard the task. Then software clears the task in the CQE. Only then the software orders CQE to resume its operation using CQCTL register. |

### 3.3.6.52 0x0438 CQTCLR Task Clear Register (Default Value: 0x0000\_0000)

This register is used for removing an outstanding task in the CQE. The register should be used only when CQE is in Halt state.

| Offset: 0x0438 |            |            | Register Name: CQTCLR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|----------------|------------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/He | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 31:0           | R/W        | 0x0        | <p>CQE_TASK_CLR<br/>Command Queuing Task Clear<br/>Writing 1 to bit <math>n</math> of this register orders CQE to clear a task which software has previously issued.<br/>This bit can only be written when CQE is in Halt state as indicated in CQCTL register Halt bit.<br/>When software writes '1' to a bit in this register, CQE updates the value to '1', and starts clearing the data structures related to the task. CQE clears the bit fields (sets a value of 0) in CQTCLR and in CQTDBR once clear operation is complete.<br/>Software should poll on the CQTCLR until it is cleared to verify clear operation was complete.<br/>Writing to this register only clears the task in the CQE and does not have impact on the device. In order to discard the task in the device, host software shall send CMDQ_TASK_MGMT while CQE is still in Halt state.<br/>Host driver is not allowed to use this register to clear multiple tasks at the same time. Clearing multiple tasks can be done using CQCTL register.<br/>Writing 0 to a register bit shall have no impact.</p> |

### 3.3.6.53 0x0440 CQSSC1 Send Status Configuration 1 Register (Default Value: 0x0001\_1000)

The register controls the when SEND\_QUEUE\_STATUS commands are sent.

| Offset: 0x0440 |            |            | Register Name: CQSSC1                                                                                                                                                                                                                                                                                                                                                          |
|----------------|------------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/He | Description                                                                                                                                                                                                                                                                                                                                                                    |
| 31:20          | /          | /          | /                                                                                                                                                                                                                                                                                                                                                                              |
| 19:16          | R/W        | 0x1        | <p>CQE_SSC_CBC<br/>Send Status Command Block Counter<br/>This field indicates to CQE when to send SEND_QUEUE_STATUS (CMD13) command to inquire the status of the device's task queue.<br/>A value of <math>n</math> means CQE shall send status command on the CMD line, during the transfer of data block BLOCK_CNT-<math>n</math>, on the data lines, where BLOCK_CNT is</p> |

| Offset: 0x0440 |            |            | Register Name: CQSSC1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|----------------|------------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/He | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                |            |            | <p>the number of blocks in the current transaction.<br/>A value of 0 means that SEND_QUEUE_STATUS (CMD13) command shall not be sent during the transaction.<br/>Instead it will be sent only when the data lines are idle.<br/>A value of 1 means that STATUS command is to be sent during the last block of the transaction.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 15:0           | R/W        | 0x1000     | <p>CQE_SSC_CIT<br/>Send Status Command Idle Timer<br/>This field indicates to CQE the polling period to use when using periodic SEND_QUEUE_STATUS (CMD13) polling.<br/>Periodic polling is used when tasks are pending in the device, but no data transfer is in progress. When a SEND_QUEUE_STATUS response indicating that no task is ready for execution, CQE counts the configured time until it issues the next SEND_QUEUE_STATUS.<br/>Timer units are clock periods of the clock whose frequency is specified in the Internal Timer Clock Frequency field CQCAP register.<br/>The minimum value is 0001h (1 clock period) and the maximum value is FFFFh (65535 clock periods). Default interval is: 4096 clock periods.<br/>For example, a CQCAP field value of 0 indicates a 19.2 MHz clock frequency (period = 52.08 ns). If the setting in CQSSC1.CIT is 1000h, the calculated polling period is <math>4096 \times 52.08 \text{ ns} = 213.33 \text{ us}</math></p> |

### 3.3.6.54 0x0444 CQSSC2 Send Status Configuration 2 Register (Default Value: 0x0000\_0000)

This register is used for configuring RCA field in SEND\_QUEUE\_STATUS command argument.

| Offset: 0x0444 |            |            | Register Name: CQSSC2                                                                                                                                                                                                                                                              |
|----------------|------------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/He | Description                                                                                                                                                                                                                                                                        |
| 31:16          | /          | /          | /                                                                                                                                                                                                                                                                                  |
| 15:0           | R/W        | 0x0        | <p>CQE_SSC_RCA<br/>Send Queue Status RCA<br/>This field provides CQE with the contents of the 16-bit RCA field in SEND_QUEUE_STATUS (CMD13) command argument.<br/>CQE shall copy this field to bits 31:16 of the argument when transmitting SEND_QUEUE_STATUS (CMD13) command.</p> |

### 3.3.6.55 0x0448 CQCRDCT Command Response for Direct-Command Task Register (Default Value: 0x0000\_0000)

This register is used for passing the response of a DCMD task to software.

| Offset: 0x0448 |            |            | Register Name: CQCRDCT                                                                                                                                                                                                                                                                                                                                              |
|----------------|------------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/He | Description                                                                                                                                                                                                                                                                                                                                                         |
| 31:0           | R          | 0x0        | <p>CQE_DCMD_LAST_RESP<br/>Direct Command Last Response<br/>This register contains the response of the command generated by the last direct- command (DCMD) task which was sent.<br/>CQE shall update this register when it receives the response for a DCMD task.<br/>This register is considered valid only after bit 31 of CQTDBR register is cleared by CQE.</p> |

### 3.3.6.56 0x0450 CQRMEM Response Mode Error Mask Register (Default Value: 0xFDF9\_A080)

This register controls the generation of Response Error Detection (RED) interrupt.

| Offset: 0x0450 |            |            | Register Name: CQRMEM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------|------------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/He | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 31:0           | R/W        | 0xFDF9A080 | <p>CQE_RMEM<br/>Response Mode Error Mask<br/>This bit is used as an interrupt mask on the device status field which is received in R1/R1b responses.<br/>Bit Value Description (for any bit 'i'):<br/>1: When a R1/R1b response is received, with bit 'i' in the device status set, a RED interrupt is generated<br/>0: When a R1/R1b response is received, bit i in the device status is ignored<br/>The reset value of this register is set to trigger an interrupt on all "Error" type bits in the device status.<br/>Note: Responses to CMD13 (SQS) encode the QSR, so they are ignored by this logic.</p> |

### 3.3.6.57 0x0454 CTERRI Task Error Information Register (Default Value: 0x0000\_0000)

This register is updated by CQE when an error occurs on data or command related to a task activity.

When such error is detected by CQE or indicated by the eMMC controller CQE stores in CTERRI the task IDs and the command indices of the commands which were executed on the command line and data lines when the error occurred.

Software is expected to use this information in the error recovery procedure.

| Offset: 0x0454 |            |            | Register Name: CQERRI                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------------|------------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/He | Description                                                                                                                                                                                                                                                                                                                                                                                                           |
| 31             | R          | 0x0        | CQE_DTE_VLD<br>Data Transfer Error Fields Valid<br>This bit is updated when an error is detected by CQE, or indicated by eMMC controller. If a data transfer is in progress when the error is detected/indicated, the bit is set to 1.<br>If a no data transfer is in progress when the error is detected/indicated, the bit is cleared to 0.                                                                         |
| 30:29          | /          | /          | /                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 28:24          | R          | 0x0        | CQE_DTE_TASK_ID<br>Data Transfer Error Task ID<br>This field indicates the ID of the task which was executed on the data lines when an error occurred.<br>The field is updated if a data transfer is in progress when an error is detected by CQE, or indicated by eMMC controller.                                                                                                                                   |
| 23:22          | /          | /          | /                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 21:16          | R          | 0x0        | CQE_DTE_CMD_IDX<br>Data Transfer Error Command Index<br>This field indicates the index of the command which was executed on the data lines when an error occurred.<br>The index shall be set to EXECUTE_READ_TASK (CMD46) or EXECUTE_WRITE_TASK (CMD47) according to the data direction.<br>The field is updated if a data transfer is in progress when an error is detected by CQE, or indicated by eMMC controller. |
| 15             | R          | 0x0        | CQE_RME_VLD<br>Response Mode Error Fields Valid<br>This bit is updated when an error is detected by CQE, or indicated by eMMC controller. If a command transaction is in progress when the error is detected/indicated, the bit is set to 1.<br>If a no command transaction is in progress when the error is detected/indicated, the bit is cleared to 0.                                                             |
| 14:13          | /          | /          | /                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 12:8           | R          | 0x0        | CQE_RME_TASK_ID<br>Response Mode Error Task ID<br>This field indicates the ID of the task which was executed on the command line when an error occurred.                                                                                                                                                                                                                                                              |

| Offset: 0x0454 |            |            | Register Name: CQERRI                                                                                                           |
|----------------|------------|------------|---------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/He | Description                                                                                                                     |
|                |            |            | The field is updated if a command transaction is in progress when an error is detected by CQE, or indicated by eMMC controller. |
| 7:6            | /          | /          | /                                                                                                                               |

  

| Offset: 0x0458 |            |            | Register Name: CQCRI                                                                                                                                                                         |
|----------------|------------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/He | Description                                                                                                                                                                                  |
| 31:6           | /          | /          | /                                                                                                                                                                                            |
| 5:0            | R          | 0x0        | CQE_LAST RESP IDX<br>Last Command Response index<br>This field stores the index of the last received command response. CQE shall update the value every time a command response is received. |

### 3.3.6.58 0x0458 CQCRI Command Response Index Register (Default Value: 0x0000\_0000)

This register stores the index of the last received command response.

| Offset: 0x0458 |            |            | Register Name: CQCRA                                                                                                                                                                      |
|----------------|------------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/He | Description                                                                                                                                                                               |
| 31:6           | /          | /          | /                                                                                                                                                                                         |
| 5:0            | R          | 0x0        | CQE_LAST RESP ARG<br>Last Command Response Argument<br>This field stores the argument of the last received command. CQE shall update the value every time a command response is received. |

### 3.3.6.59 0x045C CQCRA Command Response Argument Register (Default Value: 0x0000\_0000)

This register stores the argument of the last received command response.

| Offset: 0x045C |            |            | Register Name: CQCRA                                                                                                                                                                      |
|----------------|------------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/He | Description                                                                                                                                                                               |
| 31:0           | R          | 0x0        | CQE_LAST RESP ARG<br>Last Command Response Argument<br>This field stores the argument of the last received command. CQE shall update the value every time a command response is received. |

# Contents

|       |                              |     |
|-------|------------------------------|-----|
| 4     | Audio .....                  | 545 |
| 4.1   | Audio Codec .....            | 545 |
| 4.1.1 | Overview .....               | 545 |
| 4.1.2 | Block Diagram .....          | 546 |
| 4.1.3 | Functional Description ..... | 546 |
| 4.1.4 | Programming Guidelines ..... | 556 |
| 4.1.5 | Register List .....          | 557 |
| 4.1.6 | Register Description .....   | 561 |
| 4.2   | I2S/PCM .....                | 625 |
| 4.2.1 | Overview .....               | 625 |
| 4.2.2 | Block Diagram .....          | 626 |
| 4.2.3 | Functional Description ..... | 627 |
| 4.2.4 | Programming Guidelines ..... | 633 |
| 4.2.5 | Register List .....          | 634 |
| 4.2.6 | Register Description .....   | 636 |
| 4.3   | DMIC .....                   | 676 |
| 4.3.1 | Overview .....               | 676 |
| 4.3.2 | Block Diagram .....          | 676 |
| 4.3.3 | Functional Description ..... | 676 |
| 4.3.4 | Register List .....          | 678 |
| 4.3.5 | Register Description .....   | 679 |
| 4.4   | One Wire Audio (OWA) .....   | 690 |
| 4.4.1 | Overview .....               | 690 |
| 4.4.2 | Block Diagram .....          | 691 |
| 4.4.3 | Functional Description ..... | 691 |
| 4.4.4 | Programming Guidelines ..... | 698 |
| 4.4.5 | Register List .....          | 699 |
| 4.4.6 | Register Description .....   | 700 |

# Figures

|                                                                |     |
|----------------------------------------------------------------|-----|
| Figure 4-1 Audio Codec Block Diagram .....                     | 546 |
| Figure 4-2 Audio Codec Clock Diagram .....                     | 547 |
| Figure 4-3 Audio Codec Digital Part Reset System .....         | 548 |
| Figure 4-4 Audio Codec Analog Part Reset System .....          | 549 |
| Figure 4-5 Audio Codec Data Path Diagram .....                 | 550 |
| Figure 4-6 Headphone Output Application .....                  | 552 |
| Figure 4-7 Audio Codec Interrupt System .....                  | 552 |
| Figure 4-8 DAP Data Flow .....                                 | 553 |
| Figure 4-9 HPF Logic Structure .....                           | 553 |
| Figure 4-10 DRC static Curve Parameters .....                  | 554 |
| Figure 4-11 DRC Block Diagram .....                            | 554 |
| Figure 4-12 Energy Filter Structure .....                      | 555 |
| Figure 4-13 Gain Smooth Filter .....                           | 556 |
| Figure 4-14 I2S/PCM Interface System Block Diagram .....       | 626 |
| Figure 4-15 Typical Application of I2S/PCM Interface .....     | 626 |
| Figure 4-16 I2S Standard Mode Timing .....                     | 628 |
| Figure 4-17 Left-Justified Mode Timing .....                   | 628 |
| Figure 4-18 Right-Justified Mode Timing .....                  | 629 |
| Figure 4-19 PCM Long Frame Mode Timing .....                   | 629 |
| Figure 4-20 PCM Short Frame Mode Timing (one BCLK cycle) ..... | 629 |
| Figure 4-21 Timing Requirements for Inputs .....               | 630 |
| Figure 4-22 Timing Requirements for Outputs .....              | 631 |
| Figure 4-23 I2S/PCM Operation Flow .....                       | 632 |
| Figure 4-24 DMIC Block Diagram .....                           | 676 |
| Figure 4-25 DMIC Operation Mode .....                          | 677 |
| Figure 4-26 OWA Block Diagram .....                            | 691 |
| Figure 4-27 OWA Biphasic-Mark Code .....                       | 693 |
| Figure 4-28 OWA Sub-Frame Format .....                         | 693 |
| Figure 4-29 OWA Frame/Block Format .....                       | 694 |
| Figure 4-30 Data-Burst Format .....                            | 695 |

---

|                                                               |     |
|---------------------------------------------------------------|-----|
| Figure 4-31 Data-burst Preamble .....                         | 695 |
| Figure 4-32 Data-burst Preamble words .....                   | 696 |
| Figure 4-33 Fields of Burst-information .....                 | 696 |
| Figure 4-34 Length of the Burst-Payload Specified by Pd ..... | 697 |
| Figure 4-35 OWA Operation Flow .....                          | 698 |



# Tables

|                                                                                             |     |
|---------------------------------------------------------------------------------------------|-----|
| Table 4-1 Audio Codec External Signals .....                                                | 546 |
| Table 4-2 I2S/PCM External Signals .....                                                    | 627 |
| Table 4-3 I2S/PCM Clock Sources .....                                                       | 627 |
| Table 4-4 Proper MCLK Values with Different Fsin and Fsout .....                            | 631 |
| Table 4-5 DMIC External Signals .....                                                       | 676 |
| Table 4-6 DMIC Clock Sources .....                                                          | 677 |
| Table 4-7 OWA Sub-blocks .....                                                              | 691 |
| Table 4-8 OWA External Signals .....                                                        | 692 |
| Table 4-9 OWA_TX Clock Sources .....                                                        | 692 |
| Table 4-10 OWA_RX Clock Sources .....                                                       | 692 |
| Table 4-11 Biphase-Mark Encoder .....                                                       | 693 |
| Table 4-12 Preamble Codes .....                                                             | 694 |
| Table 4-13 Bit Allocation of Data-Burst in IEC 60958 Subframes .....                        | 695 |
| Table 4-14 The Corresponding Relation between Different System Clock and Sample Ratio ..... | 697 |

# 4 Audio

## 4.1 Audio Codec

### 4.1.1 Overview

The Audio Codec is high-performance audio encoder and decoder module which supports DAC/ADC, dynamic range controller (DRC) and dynamic voltage controller (DVC) functions.

The Audio Codec has the following features:

- Two audio digital-to-analog converter (DAC) channels
  - 16-bit and 20-bit sample resolution
  - 8 kHz to 192 kHz DAC sample rate
  - $100 \pm 2$  dB SNR@A-weight,  $-85 \pm 3$  dB THD+N
- Three audio outputs
  - One stereo headphone output: HPOUTL/R
  - Two differential lineout outputs: LINEOUTL/P/N and LINEOUTR/P/N
- Three audio analog-to-digital converter (ADC) channels
  - 16-bit and 20-bit sample resolution
  - 8 kHz to 48 kHz ADC sample rate
  - $95 \pm 3$  dB SNR@A-weight,  $-80 \pm 3$  dB THD+N
- Three differential microphone inputs: MICIN1P/1N, MICIN2P/2N, and MICIN3P/3N (for echo reduction)
- Two low-noise analog microphone bias outputs: MBIAS and HBIAS
- Supports Dynamic Range Controller adjusting the DAC playback and ADC recording
- One 128x20-bits FIFO for DAC data transmit, one 128x20-bits FIFO for ADC data receive
- Programmable FIFO thresholds
- Supports interrupts and DMA
- Internal ALDO output for AVCC

## 4.1.2 Block Diagram

The following figure shows the block diagram of Audio Codec.

**Figure 4-1 Audio Codec Block Diagram**



## 4.1.3 Functional Description

### 4.1.3.1 External Signals

**Table 4-1 Audio Codec External Signals**

| Signal Name | Description                                        | Type |
|-------------|----------------------------------------------------|------|
| MICIN1N     | Microphone Differential Negative Input 1           | AI   |
| MICIN1P     | Microphone Differential Positive Input 1           | AI   |
| MICIN2N     | Microphone Differential Negative Input 2           | AI   |
| MICIN2P     | Microphone Differential Positive Input 2           | AI   |
| MICIN3N     | Microphone Differential Negative Input 3           | AI   |
| MICIN3P     | Microphone Differential Positive Input 3           | AI   |
| LINEOUTLN   | Lineout Left Channel Negative Differential Output  | AO   |
| LINEOUTLP   | Lineout Left Channel Positive Differential Output  | AO   |
| LINEOUTRN   | Lineout Right Channel Negative Differential Output | AO   |
| LINEOUTRP   | Lineout Right Channel Positive Differential Output | AO   |
| HPOUTL      | Headphone Light Output                             | AO   |
| HPOUTR      | Headphone Right Output                             | AO   |
| HPOUTFB     | Pseudo Differential Headphone Ground Reference     | AI   |

| Signal Name | Description                                       | Type |
|-------------|---------------------------------------------------|------|
| MIC-DET     | Headphone MIC detect                              | AI   |
| HP-DET      | Headphone Jack detect                             | AI   |
| MBIAS       | First bias voltage output for main microphone     | AO   |
| HBIAS       | Second bias voltage output for headset microphone | AO   |
| CPVDD       | Analog power for headphone charge pump            | P    |
| CPVEE       | Charge pump negative voltage output               | P    |
| CPVIN       | Analog power for LDO                              | P    |
| AVCC        | Power Supply for Analog Part                      | P    |
| ALDO-OUT    | Power Supply for AVCC                             | P    |
| VDD33       | Power Supply for 3.3V Analog Part                 | P    |
| VEE         | Negative Voltage to Headphone                     | P    |
| VRA1        | Internal Reference Voltage                        | AO   |
| VRA2        | Internal Reference Voltage                        | AO   |
| VRP         | Internal Reference Voltage                        | AO   |
| AGND        | Analog Ground                                     | G    |

#### 4.1.3.2 Clock Sources

The following figure describes the clock source of Audio Codec. For clock setting, configuration, and gating information, refer to section 2.11 Power Reset Clock Management (PRCM).

Figure 4-2 Audio Codec Clock Diagram



- Digital Part

The clock sources for the digital ADC and DAC are the PLL\_AUDIO0 and PLL\_AUDIO1. Configure the CLK\_SRC\_SEL bit (bit [26:24]) of [AUDIO\\_CODEC\\_ADC\\_CLK\\_REG](#) register to select clock sources for ADC. Configure CLK\_SRC\_SEL bit (bit [26:24]) of [AUDIO\\_CODEC\\_DAC\\_CLK\\_REG](#) register to select clock sources for DAC. The PK-PK jitter of PLL\_AUDIO0 and PLL\_AUDIO1 should be less than 200 ps.

The clock source for VRA1\_SPEEDUP is CLK32K from RTC.

- Analog Part

The clock source for the analog part is the CK\_ADC and CK\_DAC, both of which are divided from the digital part.

#### 4.1.3.3 Reset System

##### Digital Part Reset System

The following figure shows the reset system of the audio codec digital part.

Figure 4-3 Audio Codec Digital Part Reset System



The MCU\_SYS\_RST comes from the VDD-SYS domain and is produced by the RTC domain which is controlled by MCU\_PRCM. Each domain has the de-bounce to confirm the reset system is strong. For the codec register part, MIX can be reset by the MCU\_SYS\_RST when being powered on or the system soft is writing the reset control logic. The other parts can be reset by the soft configuration through writing the register.

### Analog Part Reset System

The following figure shows the reset system of the audio codec analog part.

Figure 4-4 Audio Codec Analog Part Reset System



When AVCC is powered on, it sends the AVCC\_POR signal. The AVCC\_POR signal passes the level shift and RC filter part to the Audio Codec logic core.

#### 4.1.3.4 Data Path Diagram

The following figure shows a data path of the Audio Codec.

Figure 4-5 Audio Codec Data Path Diagram



#### 4.1.3.5 Three ADCs

The three ADCs are used for recording stereo sound and a reference signal. The sample rates of the three ADCs are independent of the DAC sample rate. The digital ADC part can be enabled or disabled by the bit[28] of the [AC\\_ADC\\_FIFOC](#) register.

#### 4.1.3.6 Stereo DACs

The stereo DAC sample rate can be configured by setting the register. To save power, the analog DACL can be enabled or disabled by setting the bit [15] of the [DAC\\_REG](#) register, and the analog

DACR can be enabled or disabled by setting the bit [14] of the [DAC\\_REG](#) register. The digital DAC part can be enabled or disabled by the bit [31] of the [AC\\_DAC\\_DPC](#) register.

#### 4.1.3.7 Analog Audio Input Path

The Audio Codec supports 3 analog audio input paths:

- MICIN1P/N
- MICIN2P/N
- MICIN3P/N

The MICIN is a high impedance, low capacitance input suitable for connecting to various differential microphones of different dynamics and sensitivity. The gain for each pre-amplifier can be set independently. MBIAS provide reference voltage for electret condenser type(ECM) microphones.

#### 4.1.3.8 Analog Audio Output Path

The Audio Codec has two types of analog output ports:

- LINEOUTLP
- LINEOUTLN
- LINEOUTRP
- LINEOUTRN
- HPOUTL
- HPOUTR

LINEOUTL/R

LINEOUTL/R provides one differential output to drive line signals to external audio equipment. The LINEOUTLP/N output source from DACL. The LINEOUTRP/N output source from DACR. The volume control is logarithmic with a 43.5 dB rang in 1.5 dB step from -43.5 dB to 0 dB. The LINEOUTL/R output buffer power up or down by bit [13] or bit [11] of [DAC\\_REG](#) (Offset: 0x0310).

#### Headphone Output

The headphone PA power up or down by bit [15] of [HP\\_REG](#) (Offset: 0x0324). HPOUTL/R can drive a 16R or 32R headphone load without DC capacitors by using Charge Pump to generate the negative rails. HP-FB is the ground loop noise rejection feedback. HBIAS provides reference voltage for electret condenser type (ECM) microphones.

Figure 4-6 Headphone Output Application



#### 4.1.3.9 Microphone BIAS

The MBIAS output provides a low noise reference voltage suitable for biasing electrets type microphones and the associated external resistor biasing network.

#### 4.1.3.10 Interrupt

The Audio Codec has two groups of interrupt. The following figure describes the Audio Codec interrupt system.

Figure 4-7 Audio Codec Interrupt System



#### 4.1.3.11 Digital Audio Processor (DAP)

The DAP module is used to remove the DC offset and automatically adjusts the volume to a flatten volume level. It mainly consists of two HPF and one DRC.

The following figure shows the DAP data flow.

**Figure 4-8 DAP Data Flow**



### HPF Function

The DAP has individual channel high pass filter (HPF, -3dB cutoff < 1Hz) that can be enabled and disabled. The filter cutoff frequency is less than 1 Hz that can be removed DC offset from ADC recording. The HPF can also be bypassed.

**Figure 4-9 HPF Logic Structure**



HPF transfer function is  $H(z) = \frac{1 - z^{-1}}{1 - \alpha z^{-1}}$ , that is  $y(n) = \alpha y(n-1) + x(n) - x(n-1)$ .

For cut-off frequency Fpass:  $w = F_{\text{pass}}/F_s * 2 * \pi$ . Generally,  $w$  is small. So,  $\alpha < 0, |\alpha| < 1$ .

## DRC Function

The DRC scheme has three thresholds, three offsets, and four slopes (all programmable). There is one ganged DRC for the left and right channels. The following figure shows the diagram of DRC input/output.

**Figure 4-10 DRC static Curve Parameters**



**Figure 4-11 DRC Block Diagram**



Professional-quality dynamic range compression automatically adjusts volume to flatten volume level.

One DRC for left/right and one DRC for subwoofer.

Each DRC has the adjustable threshold, offset, compression levels, programmable energy, attack, and decay time constants.

Transparent compression: Compressors can attack fast enough to avoid apparent clipping before engaging, and decay times can be set slow enough to avoid pumping.

Configure the DRC parameters according to the following guidelines:

- Number format

The Number format is N.M which means there are N bits to the left of the decimal point including the sign bit and M bits to the right of the decimal point. For example, Numbers formatted 9.23 means that there are 9 bits at the left of the decimal point and 23 bits at the right decimal point.

- Energy Filter

The following figure shows the structure of the energy filter.

**Figure 4-12 Energy Filter Structure**



The Energy Filter is to estimate of the RMS value of the audio data stream into DRC, and has two parameters, which determine the time window over which RMS to be made. The parameter is computed by  $\alpha = 1 - e^{-2.2Ts/ta}$ .

- Compression Control

This element has six parameters (ET, CT, LT, Ke, Kn, Kc, Kl, OPL, OPC, OPE), which are all programmable, and the computation will be explained as follows.

#### Threshold Parameter Computation (T parameter)

The threshold is the value that determines the signal to be compressed or not. When the signal's RMS is larger than the threshold, the signal will be compressed. The value of threshold input to the coefficient register is computed by

$$Tin = -\frac{T_{dB}}{6.0206}$$

Where,  $T_{dB}$  must less than zero, the positive value is illegal.

For example, it is desired to set CT=-40dB, then the Tin require to set CT to -40dB is CTin =  $(-40dB)/6.0206 = 6.644$ , CTin is entered as a 32-bit number in 8.24 format.

Therefore, CTin = 6.644 = 0000 0110.1010 0100 1101 0011 1100 0000 = 0x06A4 D3C0 in 8.24 format.

#### Slope Parameter Computation (K parameter)

The K is the slope within compression region. For example, a n:1 compression means that an output increase 1dB is for n dB RMS input. The k input to the coefficient ram is computed by

$$K = \frac{1}{n}$$

Where, n is from 1 to 50, and must be integer.

For example, it is desired to set 2:1, then the Kc require to set to 2:1 is  $Kc = 1/2 = 0.5$ , Kc is entered as a 32-bit number in 8.24 format.

Therefore,  $K_c = 0.5 = 0000\ 0000.1000\ 0000\ 0000\ 0000\ 0000 = 0x0080\ 0000$  in 8.24 format.

- Gain Smooth Filter

The Gain Smooth Filter is to smooth the gain and control the ratio of gain increase and decrease. The decay time and attack is shown in Figure 1-17. The structure of the Gain Smooth filter is also the Alpha filter, so the rise time computation is the same as the Energy filter which is  $\alpha = 1 - e^{-2.2T_s / t_a}$ .

**Figure 4-13 Gain Smooth Filter**



#### 4.1.4 Programming Guidelines

##### 4.1.4.1 Playing

**Step 1** Codec initialization: configure [AUDIO\\_CODEC\\_BGR\\_REG](#) and [AUDIO\\_CODEC\\_DAC\\_CLK\\_REG](#) to open the audio codec bus clock gating, release the bus reset, and open the PLL\_AUDIO DAC clock gating; set up [PLL\\_AUDIO0\\_CTRL\\_REG](#) to configure PLL\_AUDIO0 frequency and enable PLL\_AUDIO0. For details of PLL\_AUDIO0, refer to section 2.5 Clock Controller Unit (CCU).

**Step 2** Set up the sample rate and data transfer format, then open the DAC.

**Step 3** Configure the DMA and DMA request.

**Step 4** Enable the DAC DRQ and DMA.

##### 4.1.4.2 Recording

**Step 1** Codec initialization: configure [AUDIO\\_CODEC\\_BGR\\_REG](#) and [AUDIO\\_CODEC\\_ADC\\_CLK\\_REG](#) to open the audio codec bus clock gating, release the

bus reset, and open the PLL\_AUDIO1 ADC clock gating; set up [PLL\\_AUDIO1\\_CTRL\\_REG](#) to configure PLL\_AUDIO1 frequency and enable PLL\_AUDIO1. For details, refer to section 2.11 Power Reset Clock Management (PRCM).

**Step 2** Configure the sample rate and data transfer format, then open the ADC.

**Step 3** Configure the DMA and DMA request.

**Step 4** Enable the ADC DRQ and DMA.

#### 4.1.5 Register List

| Module Name | Base Address |
|-------------|--------------|
| AUDIO CODEC | 0x07110000   |

| Register Name         | Offset | Description                                              |
|-----------------------|--------|----------------------------------------------------------|
| AC_DAC_DPC            | 0x0000 | DAC Digital Part Control Register                        |
| DAC_VOL_CTRL          | 0x0004 | DAC Volume Control Register                              |
| AC_DAC_FIFOC          | 0x0010 | DAC FIFO Control Register                                |
| AC_DAC_FIFOS          | 0x0014 | DAC FIFO Status Register                                 |
| AC_DAC_TXDATA         | 0x0020 | DAC TX DATA Register                                     |
| AC_DAC_CNT            | 0x0024 | DAC TX FIFO Counter Register                             |
| AC_DAC_DG             | 0x0028 | DAC Debug Register                                       |
| AC_ADC_FIFOC          | 0x0030 | ADC FIFO Control Register                                |
| ADC_VOL_CTRL1         | 0x0034 | ADC Volume Control1 Register                             |
| AC_ADC_FIFOS          | 0x0038 | ADC FIFO Status Register                                 |
| AC_ADC_RXDATA         | 0x0040 | ADC RX Data Register                                     |
| AC_ADC_CNT            | 0x0044 | ADC RX Counter Register                                  |
| AC_ADC_DG             | 0x004C | ADC Debug Register                                       |
| ADC_DIG_CTRL          | 0x0050 | ADC Digital Control Register                             |
| VRA1SPEEDUP_DOWN_CTRL | 0x0054 | VRA1Speedup Down Control Register                        |
| AC_DAC_DAP_CTRL       | 0x00F0 | DAC DAP Control Register                                 |
| AC_ADC_DAP_CTR        | 0x00F8 | ADC DAP Control Register                                 |
| AC_DAC_DRC_HHPFC      | 0x0100 | DAC DRC High HPF Coef Register                           |
| AC_DAC_DRC_LHPFC      | 0x0104 | DAC DRC Low HPF Coef Register                            |
| AC_DAC_DRC_CTRL       | 0x0108 | DAC DRC Control Register                                 |
| AC_DAC_DRC_LPFHAT     | 0x010C | DAC DRC Left Peak Filter High Attack Time Coef Register  |
| AC_DAC_DRC_LPFLAT     | 0x0110 | DAC DRC Left Peak Filter Low Attack Time Coef Register   |
| AC_DAC_DRC_RPFHAT     | 0x0114 | DAC DRC Right Peak Filter High Attack Time Coef Register |
| AC_DAC_DRC_RPFLAT     | 0x0118 | DAC DRC Left Peak Filter Low Attack Time Coef            |

| Register Name      | Offset | Description                                                     |
|--------------------|--------|-----------------------------------------------------------------|
|                    |        | Register                                                        |
| AC_DAC_DRC_LPFHRT  | 0x011C | DAC DRC Left Peak Filter High Release Time Coef Register        |
| AC_DAC_DRC_LPFLRT  | 0x0120 | DAC DRC Left Peak Filter Low Release Time Coef Register         |
| AC_DAC_DRC_RPFHRT  | 0x0124 | DAC DRC Right Peak filter High Release Time Coef Register       |
| AC_DAC_DRC_RPFLRT  | 0x0128 | DAC DRC Right Peak filter Low Release Time Coef Register        |
| AC_DAC_DRC_LRMSHAT | 0x012C | DAC DRC Left RMS Filter High Coef Register                      |
| AC_DAC_DRC_LRMSLAT | 0x0130 | DAC DRC Left RMS Filter Low Coef Register                       |
| AC_DAC_DRC_RRMSHAT | 0x0134 | DAC DRC Right RMS Filter High Coef Register                     |
| AC_DAC_DRC_RRMSLAT | 0x0138 | DAC DRC Right RMS Filter Low Coef Register                      |
| AC_DAC_DRC_HCT     | 0x013C | DAC DRC Compressor Threshold High Setting Register              |
| AC_DAC_DRC_LCT     | 0x0140 | DAC DRC Compressor Slope High Setting Register                  |
| AC_DAC_DRC_HKC     | 0x0144 | DAC DRC Compressor Slope High Setting Register                  |
| AC_DAC_DRC_LKC     | 0x0148 | DAC DRC Compressor Slope Low Setting Register                   |
| AC_DAC_DRC_HOPC    | 0x014C | DAC DRC Compressor High Output at Compressor Threshold Register |
| AC_DAC_DRC_LOPC    | 0x0150 | DAC DRC Compressor Low Output at Compressor Threshold Register  |
| AC_DAC_DRC_HLT     | 0x0154 | DAC DRC Limiter Threshold High Setting Register                 |
| AC_DAC_DRC_LLTT    | 0x0158 | DAC DRC Limiter Threshold Low Setting Register                  |
| AC_DAC_DRC_HKI     | 0x015C | DAC DRC Limiter Slope High Setting Register                     |
| AC_DAC_DRC_LKI     | 0x0160 | DAC DRC Limiter Slope Low Setting Register                      |
| AC_DAC_DRC_HOPL    | 0x0164 | DAC DRC Limiter High Output at Limiter Threshold                |
| AC_DAC_DRC_LOPL    | 0x0168 | DAC DRC Limiter Low Output at Limiter Threshold                 |
| AC_DAC_DRC_HET     | 0x016C | DAC DRC Expander Threshold High Setting Register                |
| AC_DAC_DRC_LET     | 0x0170 | DAC DRC Expander Threshold Low Setting Register                 |
| AC_DAC_DRC_HKE     | 0x0174 | DAC DRC Expander Slope High Setting Register                    |
| AC_DAC_DRC_LKE     | 0x0178 | DAC DRC Expander Slope Low Setting Register                     |
| AC_DAC_DRC_HOPE    | 0x017C | DAC DRC Expander High Output at Expander Threshold              |
| AC_DAC_DRC_LOPE    | 0x0180 | DAC DRC Expander Low Output at Expander Threshold               |
| AC_DAC_DRC_HKN     | 0x0184 | DAC DRC Linear Slope High Setting Register                      |
| AC_DAC_DRC_LKN     | 0x0188 | DAC DRC Linear Slope Low Setting Register                       |
| AC_DAC_DRC_SFHAT   | 0x018C | DAC DRC Smooth filter Gain High Attack Time Coef Register       |
| AC_DAC_DRC_SFLAT   | 0x0190 | DAC DRC Smooth filter Gain Low Attack Time Coef                 |

| Register Name       | Offset | Description                                                |
|---------------------|--------|------------------------------------------------------------|
|                     |        | Register                                                   |
| AC_DAC_DRC_SFVRT    | 0x0194 | DAC DRC Smooth filter Gain High Release Time Coef Register |
| AC_DAC_DRC_SFLRT    | 0x0198 | DAC DRC Smooth filter Gain Low Release Time Coef Register  |
| AC_DAC_DRC_MXGHS    | 0x019C | DAC DRC MAX Gain High Setting Register                     |
| AC_DAC_DRC_MXGLS    | 0x01A0 | DAC DRC MAX Gain Low Setting Register                      |
| AC_DAC_DRC_MNGHS    | 0x01A4 | DAC DRC MIN Gain High Setting Register                     |
| AC_DAC_DRC_MNGLS    | 0x01A8 | DAC DRC MIN Gain Low Setting Register                      |
| AC_DAC_DRC_EPSHC    | 0x01AC | DAC DRC Expander Smooth Time High Coef Register            |
| AC_DAC_DRC_EPSLC    | 0x01B0 | DAC DRC Expander Smooth Time Low Coef Register             |
| AC_DAC_DRC_HPFHGAIN | 0x01B8 | DAC DRC HPF Gain High Coef Register                        |
| AC_DAC_DRC_HPFLGAIN | 0x01BC | DAC DRC HPF Gain Low Coef Register                         |
| AC_ADC_DRC_HHPFC    | 0x0200 | ADC DRC High HPF Coef Register                             |
| AC_ADC_DRC_LHPFC    | 0x0204 | ADC DRC Low HPF Coef Register                              |
| AC_ADC_DRC_CTRL     | 0x0208 | ADC DRC Control Register                                   |
| AC_ADC_DRC_LPFHAT   | 0x020C | ADC DRC Left Peak Filter High Attack Time Coef Register    |
| AC_ADC_DRC_LPFLAT   | 0x0210 | ADC DRC Left Peak Filter Low Attack Time Coef Register     |
| AC_ADC_DRC_RPFHAT   | 0x0214 | ADC DRC Right Peak Filter High Attack Time Coef Register   |
| AC_ADC_DRC_RPFLAT   | 0x0218 | ADC DRC Right Peak Filter Low Attack Time Coef Register    |
| AC_ADC_DRC_LPFHRT   | 0x021C | ADC DRC Left Peak Filter High Release Time Coef Register   |
| AC_ADC_DRC_LPFLRT   | 0x0220 | ADC DRC Left Peak Filter Low Release Time Coef Register    |
| AC_ADC_DRC_RPFHRT   | 0x0224 | ADC DRC Right Peak filter High Release Time Coef Register  |
| AC_ADC_DRC_RPFLRT   | 0x0228 | ADC DRC Right Peak filter Low Release Time Coef Register   |
| AC_ADC_DRC_LRMSHAT  | 0x022C | ADC DRC Left RMS Filter High Coef Register                 |
| AC_ADC_DRC_LRMSLAT  | 0x0230 | ADC DRC Left RMS Filter Low Coef Register                  |
| AC_ADC_DRC_RRMSHAT  | 0x0234 | ADC DRC Right RMS Filter High Coef Register                |
| AC_ADC_DRC_RRMSLAT  | 0x0238 | ADC DRC Right RMS Filter Low Coef Register                 |
| AC_ADC_DRC_HCT      | 0x023C | ADC DRC Compressor Threshold High Setting Register         |
| AC_ADC_DRC_LCT      | 0x0240 | ADC DRC Compressor Slope High Setting Register             |
| AC_ADC_DRC_HKC      | 0x0244 | ADC DRC Compressor Slope High Setting Register             |

| Register Name       | Offset | Description                                                     |
|---------------------|--------|-----------------------------------------------------------------|
| AC_ADC_DRC_LKC      | 0x0248 | ADC DRC Compressor Slope Low Setting Register                   |
| AC_ADC_DRC_HOPC     | 0x024C | ADC DRC Compressor High Output at Compressor Threshold Register |
| AC_ADC_DRC_LOPC     | 0x0250 | ADC DRC Compressor Low Output at Compressor Threshold Register  |
| AC_ADC_DRC_HLT      | 0x0254 | ADC DRC Limiter Threshold High Setting Register                 |
| AC_ADC_DRC_LLTL     | 0x0258 | ADC DRC Limiter Threshold Low Setting Register                  |
| AC_ADC_DRC_HKL      | 0x025C | ADC DRC Limiter Slope High Setting Register                     |
| AC_ADC_DRC_LKI      | 0x0260 | ADC DRC Limiter Slope Low Setting Register                      |
| AC_ADC_DRC_HOPL     | 0x0264 | ADC DRC Limiter High Output at Limiter Threshold                |
| AC_ADC_DRC_LOPL     | 0x0268 | ADC DRC Limiter Low Output at Limiter Threshold                 |
| AC_ADC_DRC_HET      | 0x026C | ADC DRC Expander Threshold High Setting Register                |
| AC_ADC_DRC_LET      | 0x0270 | ADC DRC Expander Threshold Low Setting Register                 |
| AC_ADC_DRC_HKE      | 0x0274 | ADC DRC Expander Slope High Setting Register                    |
| AC_ADC_DRC_LKE      | 0x0278 | ADC DRC Expander Slope Low Setting Register                     |
| AC_ADC_DRC_HOPE     | 0x027C | ADC DRC Expander High Output at Expander Threshold              |
| AC_ADC_DRC_LOPE     | 0x0280 | ADC DRC Expander Low Output at Expander Threshold               |
| AC_ADC_DRC_HKN      | 0x0284 | ADC DRC Linear Slope High Setting Register                      |
| AC_ADC_DRC_LKN      | 0x0288 | ADC DRC Linear Slope Low Setting Register                       |
| AC_ADC_DRC_SFHAT    | 0x028C | ADC DRC Smooth filter Gain High Attack Time Coef Register       |
| AC_ADC_DRC_SFLAT    | 0x0290 | ADC DRC Smooth filter Gain Low Attack Time Coef Register        |
| AC_ADC_DRC_SFVRT    | 0x0294 | ADC DRC Smooth filter Gain High Release Time Coef Register      |
| AC_ADC_DRC_SFLRT    | 0x0298 | ADC DRC Smooth filter Gain Low Release Time Coef Register       |
| AC_ADC_DRC_MXGHS    | 0x029C | ADC DRC MAX Gain High Setting Register                          |
| AC_ADC_DRC_MXGLS    | 0x02A0 | ADC DRC MAX Gain Low Setting Register                           |
| AC_ADC_DRC_MNGHS    | 0x02A4 | ADC DRC MIN Gain High Setting Register                          |
| AC_ADC_DRC_MNGLS    | 0x02A8 | ADC DRC MIN Gain Low Setting Register                           |
| AC_ADC_DRC_EPSHC    | 0x02AC | ADC DRC Expander Smooth Time High Coef Register                 |
| AC_ADC_DRC_EPSLC    | 0x02B0 | ADC DRC Expander Smooth Time Low Coef Register                  |
| AC_ADC_DRC_HPFHGAIN | 0x02B8 | ADC DRC HPF Gain High Coef Register                             |
| AC_ADC_DRC_HPFLGAIN | 0x02BC | ADC DRC HPF Gain Low Coef Register                              |
| ADC1_REG            | 0x0300 | ADC1 Analog Control Register                                    |
| ADC2_REG            | 0x0304 | ADC2 Analog Control Register                                    |

| Register Name | Offset | Description                       |
|---------------|--------|-----------------------------------|
| ADC3_REG      | 0x0308 | ADC3 Analog Control Register      |
| DAC_REG       | 0x0310 | DAC Analog Control Register       |
| DAC2_REG      | 0x0314 | DAC2 Analog Control Register      |
| MICBIAS_REG   | 0x0318 | MICBIAS Analog Control Register   |
| BIAS_REG      | 0x0320 | BIAS Analog Control Register      |
| HP_REG        | 0x0324 | HEADPHONE Analog Control Register |
| HMIC_CTRL     | 0x0328 | HMIC Control Register             |
| HMIC_STS      | 0x032C | HMIC Status Register              |
| POWER_REG     | 0x0348 | POWER Analog Control Register     |

#### 4.1.6 Register Description

##### 4.1.6.1 0x0000 DAC Digital Part Control Register (Default Value: 0x0000\_0100)

| Offset: 0x0000 |            |             | Register Name: AC_DAC_DPC                                                                                     |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                   |
| 31             | R/W        | 0x0         | EN_DA<br>DAC Digital Part Enable<br>0: Disable<br>1: Enable                                                   |
| 30:29          | /          | /           | /                                                                                                             |
| 28:25          | R/W        | 0x0         | MODQU<br>Internal DAC Quantization Levels<br>Levels= [7*(21+MODQU [3:0])]/128<br>Default levels=7*21/128=1.15 |
| 24             | R/W        | 0x0         | DWA<br>DWA Function Disable<br>0: Enable<br>1: Disable                                                        |
| 23:19          | /          | /           | /                                                                                                             |
| 18             | R/W        | 0x0         | HPF_EN<br>High Pass Filter Enable<br>0: Disable<br>1: Enable                                                  |
| 17:12          | R/W        | 0x0         | DVOL<br>Digital volume control: DVC, ATT=DVC [5:0]<br>*(-1.16dB)<br>64 steps, -1.16dB/step                    |
| 11             | /          | /           | /                                                                                                             |
| 10:8           | R/W        | 0x1         | DITHER_SGM<br>Dither Sigma                                                                                    |

| Offset: 0x0000 |            |             | Register Name: AC_DAC_DPC                                                                                                                                                                                                                                               |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                             |
|                |            |             | 000: Reserved<br>001: 1/2<br>010: 1/2 <sup>2</sup><br>011: 1/2 <sup>3</sup><br>100: 1/2 <sup>4</sup><br>101: 1/2 <sup>5</sup><br>110: 1/2 <sup>6</sup><br>111: Reserved                                                                                                 |
| 7:4            | R/W        | 0x0         | <b>DITHER_SFT</b><br>Dither Shift<br>Can increase the output amplitude of dither.<br>0000: x2 <sup>0</sup><br>0001: x2 <sup>1</sup><br>0010: x2 <sup>2</sup><br>0011: x2 <sup>3</sup><br>...<br>1011: x2 <sup>11</sup><br>1100: x2 <sup>12</sup><br>1101—1111: Reserved |
| 3:2            | /          | /           | /                                                                                                                                                                                                                                                                       |
| 1              | R/W        | 0x0         | <b>DITHER_EN</b><br>DSM Dither Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                                        |
| 0              | R/W        | 0x0         | <b>HUB_EN</b><br>Audio Hub Enable<br>The bit takes effect only when the EN_DA is set to 1.<br>CPUS Domain: Audio Codec/ I2S0/ I2S1/ I2S2/I2S3/<br>OWA TXFIFO Hub Enable.<br>0: Disable<br>1: Enable                                                                     |

#### 4.1.6.2 0x0004 DAC Volume Control Register (Default Value: 0x0000\_A0A0)

| Offset: 0x0004 |            |             | Register Name: DAC_VOL_CTRL                                             |
|----------------|------------|-------------|-------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                             |
| 31:17          | /          | /           | /                                                                       |
| 16             | R/W        | 0x0         | <b>DAC_VOL_SEL</b><br>DAC Volume Control Selection Enable<br>0: Disable |

| Offset: 0x0004 |            |             | Register Name: DAC_VOL_CTRL                                                                                                                                                                        |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                        |
|                |            |             | 1: Enable                                                                                                                                                                                          |
| 15:8           | R/W        | 0xA0        | DAC_VOL_L<br>DAC left channel volume<br>(-119.25dB to 71.25dB, 0.75dB/Step)<br>0x00: Mute<br>0x01: -119.25dB<br>.....<br>0x9F = -0.75dB<br>0xA0 = 0dB<br>0xA1 = 0.75dB<br>.....<br>0xFF = 71.25dB  |
| 7:0            | R/W        | 0xA0        | DAC_VOL_R<br>DAC right channel volume<br>(-119.25dB to 71.25dB, 0.75dB/Step)<br>0x00: Mute<br>0x01: -119.25dB<br>.....<br>0x9F = -0.75dB<br>0xA0 = 0dB<br>0xA1 = 0.75dB<br>.....<br>0xFF = 71.25dB |

#### 4.1.6.3 0x0010 DAC FIFO Control Register (Default Value: 0x0000\_4000)

| Offset: 0x0010 |            |             | Register Name: AC_DAC_FIFOC                                                                                                                                                                                                       |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                       |
| 31:29          | R/W        | 0x0         | DAC_FS<br>Sample Rate of DAC<br>000: 48 kHz<br>010: 24 kHz<br>100: 12 kHz<br>110: 192 kHz<br>001: 32 kHz<br>011: 16 kHz<br>101: 8 kHz<br>111: 96 kHz<br>44.1 kHz/22.05 kHz/11.025 kHz can be supported by Audio PLL Configure Bit |
| 28             | R/W        | 0           | FIR_VER                                                                                                                                                                                                                           |

| Offset: 0x0010 |            |             | Register Name: AC_DAC_FIFOC                                                                                                                                                                                                                                                                   |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                   |
|                |            |             | FIR Version<br>0: 64-Tap FIR<br>1: 32-Tap FIR                                                                                                                                                                                                                                                 |
| 27             | /          | /           | /                                                                                                                                                                                                                                                                                             |
| 26             | R/W        | 0x0         | SEND_LASAT<br>Audio sample select when TX FIFO under run<br>0: Sending zero<br>1: Sending last audio sample                                                                                                                                                                                   |
| 25:24          | R/W        | 0x0         | FIFO_MODE<br>For 20-bits transmitted audio sample:<br>00/10: FIFO_I [19:0] = {TXDATA [31:12]}<br>01/11: FIFO_I [19:0] = {TXDATA [19:0]}<br>For 16-bits transmitted audio sample:<br>00/10: FIFO_I [19:0] = {TXDATA [31:16], 4'b0}<br>01/11: FIFO_I[19:0] = {TXDATA[15:0], 4'b0}               |
| 23             | /          | /           | /                                                                                                                                                                                                                                                                                             |
| 22:21          | R/W        | 0x0         | DAC_DRQ_CLR_CNT<br>When TX FIFO available room is less than or equal N, the DRQ request will be de-asserted. N is defined here:<br>00: IRQ/DRQ De-asserted when WLEVEL > TXTL<br>01: 4<br>10: 8<br>11: 16                                                                                     |
| 20:15          | /          | /           | /                                                                                                                                                                                                                                                                                             |
| 14:8           | R/W        | 0x40        | TX_TRIG_LEVEL<br>TX FIFO Empty Trigger Level (TXTL [12:0])<br>Interrupt and DMA request trigger level for TX FIFO normal condition.<br>IRQ/DRQ Generated when WLEVEL ≤ TXTL<br>Notes:<br>WLEVEL represents the number of valid samples in the TX FIFO<br>Only TXTL[6:0] valid when TXMODE = 0 |
| 7              | /          | /           | /                                                                                                                                                                                                                                                                                             |
| 6              | R/W        | 0x0         | DAC_MONO_EN<br>DAC Mono Enable<br>0: Stereo, 64 levels FIFO<br>1: mono, 128 levels FIFO<br>When enabled, L & R channel send same data                                                                                                                                                         |
| 5              | R/W        | 0x0         | TX_SAMPLE_BITS                                                                                                                                                                                                                                                                                |

| Offset: 0x0010 |            |             | Register Name: AC_DAC_FIFOC                                                      |
|----------------|------------|-------------|----------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                      |
|                |            |             | Transmitting Audio Sample Resolution<br>0: 16 bits<br>1: 20 bits                 |
| 4              | R/W        | 0x0         | DAC_DRQ_EN<br>DAC FIFO Empty DRQ Enable<br>0: Disable<br>1: Enable               |
| 3              | R/W        | 0x0         | DAC_IRQ_EN<br>DAC FIFO Empty IRQ Enable<br>0: Disable<br>1: Enable               |
| 2              | R/W        | 0x0         | FIFO_UNDERRUN_IRQ_EN<br>DAC FIFO Under Run IRQ Enable<br>0: Disable<br>1: Enable |
| 1              | R/W        | 0x0         | FIFO_OVERRUN_IRQ_EN<br>DAC FIFO Over Run IRQ Enable<br>0: Disable<br>1: Enable   |
| 0              | R/WC       | 0x0         | FIFO_FLUSH<br>DAC FIFO Flush<br>Write '1' to flush TX FIFO, self clear to '0'    |

#### 4.1.6.4 0x0014 DAC FIFO Status Register (Default Value: 0x0080\_8008)

| Offset: 0x0014 |            |             | Register Name: AC_DAC_FIFOS                                                                                                                                   |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                   |
| 31:24          | /          | /           | /                                                                                                                                                             |
| 23             | R          | 0x1         | TX_EMPTY<br>TX FIFO Empty<br>0: No room for new sample in TX FIFO<br>1: More than one room for new sample in TX FIFO<br>(>= 1 word)                           |
| 22:8           | R          | 0x80        | TXE_CNT<br>TX FIFO Empty Space Word Counter                                                                                                                   |
| 7:4            | /          | /           | /                                                                                                                                                             |
| 3              | R/WC       | 0x1         | TXE_INT<br>TX FIFO Empty Pending Interrupt<br>0: No Pending IRQ<br>1: FIFO Empty Pending Interrupt<br>Write '1' to clear this interrupt or automatic clear if |

| Offset: 0x0014 |            |             | Register Name: AC_DAC_FIFOS                                                                                                                                      |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                      |
|                |            |             | interrupt condition fails.                                                                                                                                       |
| 2              | R/WC       | 0x0         | <p>TXU_INT<br/>TX FIFO Under run Pending Interrupt<br/>0: No Pending Interrupt<br/>1: FIFO Under run Pending Interrupt<br/>Write '1' to clear this interrupt</p> |
| 1              | R/WC       | 0x0         | <p>TXO_INT<br/>TX FIFO Overrun Pending Interrupt<br/>0: No Pending Interrupt<br/>1: FIFO Overrun Pending Interrupt<br/>Write '1' to clear this interrupt</p>     |
| 0              | /          | /           | /                                                                                                                                                                |

#### 4.1.6.5 0x0020 DAC TX DATA Register (Default Value: 0x0000\_0000)

| Offset: 0x0020 |            |             | Register Name: AC_DAC_TXDATA                                                                                                                                                                     |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                      |
| 31:0           | W          | 0x0         | <p>TX_DATA<br/>Transmitting left, right channel sample data<br/>should be written this register one by one. The left<br/>channel sample data is first and then the right<br/>channel sample.</p> |

#### 4.1.6.6 0x0024 DAC TX FIFO Counter Register (Default Value: 0x0000\_0000)

| Offset: 0x0024 |            |             | Register Name: AC_DAC_CNT                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 31:0           | R/W        | 0x0         | <p>TX_CNT<br/>TX Sample Counter<br/>The audio sample number of sending into TXFIFO.<br/>When one sample is put into TXFIFO by DMA or by<br/>host IO, the TX sample counter register increases<br/>by one. The TX sample counter register can be set<br/>to any initial value at any time. After been updated<br/>by the initial value, the counter register should<br/>count on base of this initial value.<br/>Notes: It is used for Audio/ Video Synchronization</p> |

#### 4.1.6.7 0x0028 DAC Debug Register (Default Value: 0x0000\_0000)

| Offset: 0x0028 |            |             | Register Name: AC_DAC_DG                                                                                                                                                          |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                       |
| 31:12          | /          | /           | /                                                                                                                                                                                 |
| 11             | R/W        | 0x0         | DAC_MODU_SELECT<br>DAC Modulator Debug<br>0: DAC Modulator Normal Mode<br>1: DAC Modulator Debug Mode                                                                             |
| 10:9           | R/W        | 0x0         | DAC_PATTERN_SELECT<br>DAC Pattern Select<br>00: Normal (Audio Sample from TX FIFO)<br>01: -6 dB Sin wave<br>10: -60 dB Sin wave<br>11: silent wave                                |
| 8              | R/W        | 0x0         | CODEC_CLK_SELECT<br>CODEC Clock Source Select: cksel<br>0: CODEC Clock from PLL<br>1: CODEC Clock from OSC (for Debug)                                                            |
| 7              | /          | /           | /                                                                                                                                                                                 |
| 6              | R/W        | 0x0         | DA_SWP<br>DAC output channel swap enable, DA_SWP<br>0: Disable<br>1: Enable                                                                                                       |
| 5:3            | /          | /           | /                                                                                                                                                                                 |
| 2:0            | R/W        | 0x0         | ADDA_LOOP_MODE<br>Audio Codec Loop MODE SELECT<br>000: Disable<br>001: ADDA LOOP MODE DACL/DACR connect to ADC1/ADC2<br>010: ADDA LOOP MODE DACL connect to ADC3<br>1xx: Reserved |

#### 4.1.6.8 0x0030 ADC FIFO Control Register (Default Value: 0x0000\_0400)

| Offset: 0x0030 |            |             | Register Name: AC_ADC_FIFOC                                             |
|----------------|------------|-------------|-------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                             |
| 31:29          | R/W        | 0x0         | ADFS<br>Sample Rate of ADC<br>000: 48 kHz<br>010: 24 kHz<br>100: 12 kHz |

| Offset: 0x0030 |            |             | Register Name: AC_ADC_FIFOC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                |            |             | <p>110: Reserved<br/>         001: 32 kHz<br/>         011: 16 kHz<br/>         101: 8 kHz<br/>         111: Reserved<br/>         44.1 kHz/22.05 kHz/11.025 kHz can be supported by Audio PLL Configure Bit</p>                                                                                                                                                                                                                                                                                                                                                          |
| 28             | R/W        | 0x0         | <p>EN_AD<br/>         ADC Digital Part Enable<br/>         0: Disable<br/>         1: Enable</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 27:26          | R/W        | 0x0         | <p>ADCFDT<br/>         ADC FIFO Delay Time for writing Data after EN_AD<br/>         00:5ms<br/>         01:10ms<br/>         10:20ms<br/>         11:30ms</p>                                                                                                                                                                                                                                                                                                                                                                                                            |
| 25             | R/W        | 0x0         | <p>ADCDFEN<br/>         ADC FIFO Delay Function for writing Data after EN_AD<br/>         0: Disable<br/>         1: Enable</p>                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 24             | R/W        | 0x0         | <p>RX_FIFO_MODE<br/>         RX FIFO Output Mode (Mode 0, 1)<br/>         0: Expanding '0' at LSB of TX FIFO register<br/>         1: Expanding received sample sign bit at MSB of TX FIFO register<br/>         For 20-bits received audio sample:<br/>         Mode 0: RXDATA [31:0] = {FIFO_O [19:0], 12'h0}<br/>         Mode 1: RXDATA [31:0] = {12{FIFO_O [19]}, FIFO_O [19:0]}<br/>         For 16-bits received audio sample:<br/>         Mode 0: RXDATA [31:0] = {FIFO_O [19:4], 16'h0}<br/>         Mode 1: RXDATA[31:0] = {16{FIFO_O[19]}}, FIFO_O[19:4]}</p> |
| 23:22          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 21             | R/W        | 0x0         | <p>RX_SYNC_EN_START<br/>         Only if RX_SYNC_EN set 1, RX_SYNC_EN_START can take effect.<br/>         CPUS Domain: Audio Codec/ I2S0/ I2S1/ I2S2/ DMIC/ OWA RX</p>                                                                                                                                                                                                                                                                                                                                                                                                    |

| Offset: 0x0030 |            |             | Register Name: AC_ADC_FIFOC                                                                                                                                                                                                                                  |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                  |
|                |            |             | Synchronize Enable Start.<br>0: Disable<br>1: Enable                                                                                                                                                                                                         |
| 20             | R/W        | 0x0         | RX_SYNC_EN<br>AudioCodec RX Synchronize Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                    |
| 19:17          | /          | /           | /                                                                                                                                                                                                                                                            |
| 16             | R/W        | 0x0         | RX_SAMPLE_BITS<br>Receiving Audio Sample Resolution<br>0: 16 bits<br>1: 20 bits                                                                                                                                                                              |
| 15:12          | /          | /           | /                                                                                                                                                                                                                                                            |
| 11:4           | R/W        | 0x40        | RX_FIFO_TRG_LEVEL<br>RX FIFO Trigger Level (RXTL [5:0])<br>Interrupt and DMA request trigger level for RX FIFO<br>normal condition<br>IRQ/DRQ Generated when WLEVEL > RXTL[5:0]<br>Notes:<br>WLEVEL represents the number of valid samples in<br>the RX FIFO |
| 3              | R/W        | 0x0         | ADC_DRQ_EN<br>ADC FIFO Data Available DRQ Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                  |
| 2              | R/W        | 0x0         | ADC_IRQ_EN<br>ADC FIFO Data Available IRQ Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                  |
| 1              | R/W        | 0x0         | ADC_OVERRUN_IRQ_EN<br>ADC FIFO Over Run IRQ Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                |
| 0              | R/WC       | 0x0         | ADC_FIFO_FLUSH<br>ADC FIFO Flush<br>Write '1' to flush TX FIFO, self-clear to '0'.                                                                                                                                                                           |

#### 4.1.6.9 0x0034 ADC Volume Control1 Register (Default Value: 0xA0A0\_A0A0)

| Offset: 0x0034 |            |             | Register Name: ADC_VOL_CTRL1 |
|----------------|------------|-------------|------------------------------|
| Bit            | Read/Write | Default/Hex | Description                  |

| Offset: 0x0034 |            |             | Register Name: ADC_VOL_CTRL1                                                                                                                                                                 |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                  |
| 31:24          | R          | 0xA0        | PLACE HOLDER<br>No meaning                                                                                                                                                                   |
| 23:16          | R/W        | 0xA0        | ADC3_VOL<br>ADC3 channel volume<br>(-119.25dB to 71.25dB, 0.75dB/Step)<br>0x00: Mute<br>0x01: -119.25dB<br>.....<br>0x9F = -0.75dB<br>0xA0 = 0dB<br>0xA1 = 0.75dB<br>.....<br>0xFF = 71.25dB |
| 15:8           | R/W        | 0xA0        | ADC2_VOL<br>ADC2 channel volume<br>(-119.25dB to 71.25dB, 0.75dB/Step)<br>0x00: Mute<br>0x01: -119.25dB<br>.....<br>0x9F = -0.75dB<br>0xA0 = 0dB<br>0xA1 = 0.75dB<br>.....<br>0xFF = 71.25dB |
| 7:0            | R/W        | 0xA0        | ADC1_VOL<br>ADC1 channel volume<br>(-119.25dB to 71.25dB, 0.75dB/Step)<br>0x00: Mute<br>0x01: -119.25dB<br>.....<br>0x9F = -0.75dB<br>0xA0 = 0dB<br>0xA1 = 0.75dB<br>.....<br>0xFF = 71.25dB |

#### 4.1.6.10 0x0038 ADC FIFO Status Register (Default Value: 0x0000\_0001)

| Offset: 0x0038 |            |             | Register Name: AC_ADC_FIFOS |
|----------------|------------|-------------|-----------------------------|
| Bit            | Read/Write | Default/Hex | Description                 |
| 31:24          | /          | /           | /                           |

| Offset: 0x0038 |            |             | Register Name: AC_ADC_FIFOS                                                                                                                                                                     |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                     |
| 23             | R          | 0x0         | RXA<br>RX FIFO Available<br>0: No available data in RX FIFO<br>1: More than one sample in RX FIFO ( $\geq 1$ word)                                                                              |
| 22:17          | /          | /           | /                                                                                                                                                                                               |
| 16:8           | R          | 0x0         | RXA_CNT<br>RX FIFO Available Sample Word Counter                                                                                                                                                |
| 7:4            | /          | /           | /                                                                                                                                                                                               |
| 3              | R/WC       | 0x0         | RXA_INT<br>RX FIFO Data Available Pending Interrupt<br>0: No Pending IRQ<br>1: Data Available Pending IRQ<br>Write '1' to clear this interrupt or automatic clear if interrupt condition fails. |
| 2              | /          | /           | /                                                                                                                                                                                               |
| 1              | R/WC       | 0x0         | RXO_INT<br>RX FIFO Overrun Pending Interrupt<br>0: No Pending IRQ<br>1: FIFO Overrun Pending IRQ<br>Write '1' to clear this interrupt                                                           |
| 0              | R          | 0x1         | PLACEHOLDER<br>No meaning                                                                                                                                                                       |

#### 4.1.6.11 0x0040 ADC RX Data Register (Default Value: 0x0000\_0000)

| Offset: 0x0040 |            |             | Register Name: AC_ADC_RXDATA                                                                                                                          |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                           |
| 31:0           | R          | 0x0         | RX_DATA<br>RX Sample<br>Host can get one sample by reading this register.<br>The left channel sample data is first and then the right channel sample. |

#### 4.1.6.12 0x0044 ADC RX Counter Register (Default Value: 0x0000\_0000)

| Offset: 0x0044 |            |             | Register Name: AC_ADC_CNT                                                      |
|----------------|------------|-------------|--------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                    |
| 31:0           | R/W        | 0x0         | RX_CNT<br>RX Sample Counter<br>The audio sample number of writing into RXFIFO. |

| Offset: 0x0044 |            |             | Register Name: AC_ADC_CNT                                                                                                                                                                                                                                                                                                                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                 |
|                |            |             | <p>When one sample is written by Digital Audio Engine, the RX sample counter register increases by one. The RX sample counter register can be set to any initial value at any time. After been updated by the initial value, the counter register should count on base of this initial value.</p> <p>Notes: It is used for Audio/ Video Synchronization</p> |

#### 4.1.6.13 0x004C ADC Debug Register (Default Value: 0x0000\_0000)

| Offset: 0x004C |            |             | Register Name: AC_ADC_DG                                                                                                                     |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                  |
| 31:26          | /          | /           | /                                                                                                                                            |
| 25             | R/W        | 0x0         | <p>AD_SWP2<br/>ADC output channel swap enable (for digital filter)<br/>0: Disable<br/>1: Enable<br/>Note:ADC3 and ADC4(2` b0) swap data.</p> |
| 24             | R/W        | 0x0         | <p>AD_SWP1<br/>ADC output channel swap enable (for digital filter)<br/>0: Disable<br/>1: Enable<br/>Note:ADC1 and ADC2 swap data.</p>        |
| 23:0           | /          | /           | /                                                                                                                                            |

#### 4.1.6.14 0x0050 ADC Digital Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0050 |            |             | Register Name: ADC_DIG_CTRL                                                        |
|----------------|------------|-------------|------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                        |
| 31:18          | /          | /           | /                                                                                  |
| 17             | R/W        | 0x0         | <p>ADC3_VOL_EN<br/>ADC3 Volume Control Enable<br/>0: Disable<br/>1: Enable</p>     |
| 16             | R/W        | 0x0         | <p>ADC1_2_VOL_EN<br/>ADC1/2 Volume Control Enable<br/>0: Disable<br/>1: Enable</p> |
| 15:3           | /          | /           | /                                                                                  |

| Offset: 0x0050 |            |             | Register Name: ADC_DIG_CTRL                                                      |
|----------------|------------|-------------|----------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                      |
| 2:0            | R/W        | 0x0         | ADC_CHANNEL_EN<br>Bit 2: ADC3 enable<br>Bit 1: ADC2 enable<br>Bit 0: ADC1 enable |

#### 4.1.6.15 0x0054 VRA1Speedup Down Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0054 |            |             | Register Name: VRA1SPEEDUP_DOWN_CTRL                                                                                                                                                              |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                       |
| 31:05          | /          | /           | /                                                                                                                                                                                                 |
| 4              | R          | 0x0         | VRA1SPEEDUP_DOWN_STATE<br>Only if VAR1SPEEDUP_DOWN_Further_CTRL (0x310[22]) set 0,<br>VAR1Speedup Down State is valid.<br>0: VAR1Speedup_Down not work<br>1: VAR1Speedup_Down work                |
| 3:2            | /          | /           | /                                                                                                                                                                                                 |
| 1              | R/W        | 0x0         | VRA1SPEEDUP_DOWN_CTRL<br>VAR1Speedup Down Manual Control Enable<br>0: Disable, VAR1Speedup Down convert 1 after bus RST release 32ms.<br>1: Enable, VAR1Speedup Down convert 1 immediately.       |
| 0              | R/W        | 0x0         | VRA1SPEEDUP_DOWN_RST_CTRL<br>VAR1Speedup Down RST Manual Control Enable<br>0: Disable, VAR1Speedup Down convert 1 after bus RST release 32ms.<br>1: Enable, VAR1Speedup Down reset 0 immediately. |

#### 4.1.6.16 0x00F0 DAC DAP Control Register (Default Value: 0x0000\_0000)

| Offset: 0x00F0 |            |             | Register Name: AC_DAC_DAP_CTRL                          |
|----------------|------------|-------------|---------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                             |
| 31             | R/W        | 0X0         | DDAP_EN<br>DAP for DRC Enable<br>0: Bypass<br>1: Enable |
| 30             | /          | /           | /                                                       |
| 29             | R/W        | 0X0         | DDAP_DRC_EN                                             |

| Offset: 0x00F0 |            |             | Register Name: AC_DAC_DAP_CTRL                               |
|----------------|------------|-------------|--------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                  |
|                |            |             | DRC Enable Control<br>0: Disable<br>1: Enable                |
| 28             | R/W        | 0X0         | DDAP_HPF_EN<br>HPF Enable Control<br>0: Disable<br>1: Enable |
| 27:0           | /          | /           | /                                                            |

#### 4.1.6.17 0x00F8 ADC DAP Control Register (Default Value: 0x0000\_0000)

| Offset: 0x00F8 |            |             | Register Name: AC_ADC_DAP_CTR                                                                                               |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                 |
| 31             | R/W        | 0x0         | ADC_DAP0_EN<br>DAP for ADC1/2 Enable<br>(Adjust the position, and two DRCs use the same parameter)<br>0: bypass<br>1:enable |
| 30             | /          | /           | /                                                                                                                           |
| 29             | R/W        | 0x0         | ADC_DRC0_EN<br>ADC DRC0 Enable Control<br>0: disable<br>1:enable                                                            |
| 28             | R/W        | 0x0         | ADC_HPF0_EN<br>ADC HPF0 Enable Control<br>0: disable<br>1:enable                                                            |
| 27             | R/W        | 0x0         | ADC_DAP1_EN<br>ADC DAP1 Enable Control<br>This bit is to control the DAP for ADC3.                                          |
| 26             | /          | /           | /                                                                                                                           |
| 25             | R/W        | 0x0         | ADC_DRC1_EN<br>ADC DRC1 enable control<br>0: disable<br>1:enable                                                            |
| 24             | R/W        | 0x0         | ADC_HPF1_EN<br>ADC HPF1 enable control<br>0: disable<br>1:enable                                                            |

| Offset: 0x00F8 |            |             | Register Name: AC_ADC_DAP_CTR |
|----------------|------------|-------------|-------------------------------|
| Bit            | Read/Write | Default/Hex | Description                   |
| 23:0           | /          | /           | /                             |

#### 4.1.6.18 0x0100 DAC DRC High HPF Coef Register (Default Value: 0x0000\_00FF)

| Offset: 0x0100 |            |             | Register Name: AC_DAC_DRC_HHPFC                                          |
|----------------|------------|-------------|--------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                              |
| 31:11          | /          | /           | /                                                                        |
| 10:0           | R/W        | 0xFF        | DAC_DRC_HHPF_COE<br>HPF coefficient setting and the data is 3.24 format. |

#### 4.1.6.19 0x0104 DAC DRC Low HPF Coef Register (Default Value: 0x0000\_FAC1)

| Offset: 0x0104 |            |             | Register Name: AC_DAC_DRC_LHPFC                                          |
|----------------|------------|-------------|--------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                              |
| 31:16          | /          | /           | /                                                                        |
| 15:0           | R/W        | 0xFAC1      | DAC_DRC_LHPF_COE<br>HPF coefficient setting and the data is 3.24 format. |

#### 4.1.6.20 0x0108 DAC DRC Control Register (Default Value: 0x0000\_0080)

| Offset: 0x0108 |            |             | Register Name: AC_DAC_DRC_CTRL                                                                                                                                                                                                                                              |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                 |
| 31:16          | /          | /           | /                                                                                                                                                                                                                                                                           |
| 15             | R          | 0           | DAC_DRC_DELAY_BUF_STATE<br>DRC delay buffer data output state when DRC delay function is enable and the DRC function disable. After disable DRC function and this bit go to 0, the user should write the DRC delay function bit to 0;<br>0: not complete<br>1 : is complete |
| 14:10          | /          | /           | /                                                                                                                                                                                                                                                                           |
| 13:8           | R/W        | 0           | DAC_DRC_SIGNAL_DELAY_TIME_SET<br>Signal delay time setting<br>6'h00: (8x1) fs<br>6'h01: (8x2) fs<br>6'h02: (8x3) fs<br>-----<br>6'h2e: (8*47) fs                                                                                                                            |

| Offset: 0x0108 |            |             | Register Name: AC_DAC_DRC_CTRL                                                                                                                                                                                                                                                                                                                                                                                                                    |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                |            |             | 6'h2f: (8*48) fs<br>6'h30 -- 6'h3f: (8*48) fs<br>Delay time = 8*(n+1) fs, n<6'h30;<br>When the delay function is disable, the signal delay time is unused.                                                                                                                                                                                                                                                                                        |
| 7              | R/W        | 0x1         | DAC_DRC_DELAY_BUF_EN<br>The delay buffer use or not when the DRC disable and the DRC buffer data output completely<br>0: don't use the buffer<br>1 : use the buffer                                                                                                                                                                                                                                                                               |
| 6              | R/W        | 0x0         | DAC_DRC_GAIN_MAX_LIMIT_EN<br>DRC gain max limit enable<br>0: disable<br>1 : enable                                                                                                                                                                                                                                                                                                                                                                |
| 5              | R/W        | 0x0         | DAC_DRC_GAIN_MIN_LIMIT_EN<br>DRC gain min limit enable. when this function enables, it will overwrite the noise detect function.<br>0: disable<br>1 : enable                                                                                                                                                                                                                                                                                      |
| 4              | R/W        | 0x0         | DAC_DRC_DETECT_NOISE_EN<br>Control the DRC to detect noise when ET enable<br>0: disable<br>1 : enable                                                                                                                                                                                                                                                                                                                                             |
| 3              | R/W        | 0x0         | DAC_DRC_SIGNAL_FUNC_SEL<br>Signal function Select<br>0: RMS filter<br>1: Peak filter<br>When signal function selects Peak filter, the RMS parameter is unused. (AC_DRC_LRMSHAT / AC_DRC_LRMSLAT / AC_DRC_LRMSHAT / AC_DRC_LRMSLAT)<br>When Signal function Select RMS filter, the Peak filter parameter is unused.(AC_DRC_LPFHAT / AC_DRC_LPFLAT / AC_DRC_RPFHAT / AC_DRC_RPFLAT / AC_DRC_LPFHRT / AC_DRC_LPFLRT / AC_DRC_RPFHRT / AC_DRC_RPFLRT) |
| 2              | R/W        | 0x0         | DAC_DRC_DELAY_FUNC_EN<br>Delay function enable<br>0: disable<br>1: enable                                                                                                                                                                                                                                                                                                                                                                         |

| Offset: 0x0108 |            |             | Register Name: AC_DAC_DRC_CTRL                                                                                                  |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                     |
|                |            |             | When the Delay function enable is disable, the Signal delay time is unused.                                                     |
| 1              | R/W        | 0x0         | DAC_DRC_LT_EN<br>DRC LT enable<br>0: disable<br>1: enable<br>When the DRC LT is disable the LT, KI and OPL parameter is unused. |
| 0              | R/W        | 0x0         | DAC_DRC_ET_EN<br>DRC ET enable<br>0: disable<br>1: enable<br>When the DRC ET is disable the ET, Ke and OPE parameter is unused. |

#### 4.1.6.21 0x010C DAC DRC Left Peak Filter High Attack Time Coef Register (Default Value: 0x0000\_000B)

| Offset: 0x010C |            |             | Register Name: AC_DAC_DRC_LPFHAT                                                                                                                                                 |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                      |
| 31:11          | /          | /           | /                                                                                                                                                                                |
| 10:0           | R/W        | 0x000B      | DAC_DRC_LPFHAT<br>The left peak filter attack time parameter setting, which determine by the equation that AT = 1-exp(-2.2Ts/ta). The format is 3.24. (The default value is 1ms) |

#### 4.1.6.22 0x0110 DAC DRC Left Peak Filter Low Attack Time Coef Register (Default Value: 0x0000\_77BF)

| Offset: 0x0110 |            |             | Register Name: AC_DAC_DRC_LPFLAT                                                                                                                                                 |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                      |
| 31:16          | /          | /           | /                                                                                                                                                                                |
| 15:0           | R/W        | 0x77BF      | DAC_DRC_LPFLAT<br>The left peak filter attack time parameter setting, which determine by the equation that AT = 1-exp(-2.2Ts/ta). The format is 3.24. (The default value is 1ms) |

**4.1.6.23 0x0114 DAC DRC Right Peak Filter High Attack Time Coef Register (Default Value: 0x0114\_0x0000\_000B)**

| Offset: 0x0114 |            |             | Register Name: AC_DAC_DRC_RPFHAT                                                                                                                                                  |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                       |
| 31:16          | /          | /           | /                                                                                                                                                                                 |
| 15:0           | R/W        | 0x000B      | DAC_DRC_RPFHAT<br>The right peak filter attack time parameter setting, which determine by the equation that AT = 1-exp(-2.2Ts/ta). The format is 3.24. (The default value is 1ms) |

**4.1.6.24 0x0118 DAC DRC Left Peak Filter Low Attack Time Coef Register (Default Value: 0x0000\_77BF)**

| Offset: 0x0118 |            |             | Register Name: AC_DAC_DRC_RPFLAT                                                                                                                                                 |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                      |
| 31:16          | /          | /           | /                                                                                                                                                                                |
| 15:0           | R/W        | 0x77BF      | DAC_DRC_RPFLAT<br>The left peak filter attack time parameter setting, which determine by the equation that AT = 1-exp(-2.2Ts/ta). The format is 3.24. (The default value is 1ms) |

**4.1.6.25 0x011CDAC DRC Left Peak Filter High Release Time Coef Register (Default Value: 0x0000\_00FF)**

| Offset: 0x011C |            |             | Register Name: AC_DAC_DRC_LPFHRT                                                                                                                                                  |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                       |
| 31:11          | /          | /           | /                                                                                                                                                                                 |
| 10:0           | R/W        | 0x00FF      | DAC_DRC_LPFHRT<br>The left peak filter release time parameter setting, which determine by the equation that RT = exp(-2.2Ts/tr). The format is 3.24. (The default value is 100ms) |

**4.1.6.26 0x0120 DAC DRC Left Peak Filter Low Release Time Coef Register (Default Value: 0x0000\_E1F8)**

| Offset: 0x0120 |            |             | Register Name: AC_DAC_DRC_LPFLRT                                       |
|----------------|------------|-------------|------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                            |
| 31:16          | /          | /           | /                                                                      |
| 15:0           | R/W        | 0xE1F8      | DAC_DRC_LPFLRT<br>The left peak filter release time parameter setting, |

| Offset: 0x0120 |            |             | Register Name: AC_DAC_DRC_LPFLRT                                                                           |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                |
|                |            |             | which determine by the equation that RT = exp(-2.2Ts/tr). The format is 3.24. (The default value is 100ms) |

#### 4.1.6.27 0x0124 DAC DRC Right Peak filter High Release Time Coef Register (Default Value: 0x0000\_00FF)

| Offset: 0x0124 |            |             | Register Name: AC_DAC_DRC_RPFHRT                                                                                                                                                  |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                       |
| 31:16          | /          | /           | /                                                                                                                                                                                 |
| 15:0           | R/W        | 0x00FF      | DAC_DRC_RPFHRT<br>The right peak filter attack time parameter setting, which determine by the equation that RT = exp(-2.2Ts/tr). The format is 3.24. (The default value is 100ms) |

#### 4.1.6.28 0x0128 DAC DRC Right Peak Filter Low Release Time Coef Register (Default Value: 0x0000\_E1F8)

| Offset: 0x0128 |            |             | Register Name: AC_DAC_DRC_RPFLRT                                                                                                                                                   |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                        |
| 31:16          | /          | /           | /                                                                                                                                                                                  |
| 15:0           | R/W        | 0xE1F8      | DAC_DRC_RPFLRT<br>The right peak filter release time parameter setting, which determine by the equation that AT = exp(-2.2Ts/tr). The format is 3.24. (The default value is 100ms) |

#### 4.1.6.29 0x012CDAC DRC Left RMS Filter High Coef Register (Default Value: 0x0000\_0001)

| Offset: 0x012C |            |             | Register Name: AC_DAC_DRC_LRMSHAT                                                                                                                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                        |
| 31:11          | /          | /           | /                                                                                                                                                                                  |
| 10:0           | R/W        | 0x0001      | DAC_DRC_LRMSHAT<br>The left RMS filter average time parameter setting, which determine by the equation that AT = 1-exp(-2.2Ts/tav). The format is 3.24.(The default value is 10ms) |

**4.1.6.30 0x0130 DAC DRC Left RMS Filter Low Coef Register (Default Value: 0x0000\_2BAF)**

| Offset: 0x0130 |            |             | Register Name: AC_DAC_DRC_LRMSLAT                                                                                                                                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                         |
| 31:16          | /          | /           | /                                                                                                                                                                                   |
| 15:0           | R/W        | 0x2BAF      | DAC_DRC_LRMSLAT<br>The left RMS filter average time parameter setting, which determine by the equation that AT = 1-exp(-2.2Ts/tav). The format is 3.24. (The default value is 10ms) |

**4.1.6.31 0x0134 DAC DRC Right RMS Filter High Coef Register (Default Value: 0x0000\_0001)**

| Offset: 0x0134 |            |             | Register Name: AC_DAC_DRC_RRMSHAT                                                                                                                                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                         |
| 31:16          | /          | /           | /                                                                                                                                                                                   |
| 15:0           | R/W        | 0x0001      | DAC_DRC_RRMSHAT<br>The right RMS filter average time parameter setting, which determine by the equation that AT = 1-exp(-2.2Ts/tav). The format is 3.24.(The default value is 10ms) |

**4.1.6.32 0x0138 DAC DRC Right RMS Filter Low Coef Register (Default Value: 0x0000\_2BAF)**

| Offset: 0x0138 |            |             | Register Name: AC_DAC_DRC_RRMSLAT                                                                                                                              |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                    |
| 31:16          | /          | /           | /                                                                                                                                                              |
| 15:0           | R/W        | 0x2BAF      | DAC_DRC_RRMSLAT<br>The right RMS filter average time parameter setting, which determine by the equation that AT = 1-exp(-2.2Ts/tav). The format is 3.24.(10ms) |

**4.1.6.33 0x013CDAC DRC Compressor Threshold High Setting Register (Default Value: 0x0000\_06A4)**

| Offset: 0x013C |            |             | Register Name: AC_DAC_DRC_HCT                                                                                                                       |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                         |
| 31:16          | /          | /           | /                                                                                                                                                   |
| 15:0           | R/W        | 0x06A4      | DAC_DRC_HCT<br>The compressor threshold setting, which set by the equation that CTin = -CT/6.0206. The format is 8.24. (The default value is -40dB) |

#### 4.1.6.34 0x0140 DAC DRC Compressor Slope High Setting Register (Default Value: 0x0000\_D3C0)

| Offset: 0x0140 |            |             | Register Name: AC_DAC_DRC_LCT                                                                                                                          |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                            |
| 31:16          | /          | /           | /                                                                                                                                                      |
| 15:0           | R/W        | 0xD3C0      | DAC_DRC_LCT<br>The compressor threshold setting, which set by the equation that $CTin = -CT/6.0206$ . The format is 8.24. (The default value is -40dB) |

#### 4.1.6.35 0x0144 DAC DRC Compressor Slope High Setting Register (Default Value: 0x0000\_0080)

| Offset: 0x0144 |            |             | Register Name: AC_DAC_DRC_HKC                                                                                                                                                                                     |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                       |
| 31:16          | /          | /           | /                                                                                                                                                                                                                 |
| 15:0           | R/W        | 0x0080      | DAC_DRC_HKC<br>The slope of the compressor which determine by the equation that $Kc = 1/R$ , there, R is the ratio of the compressor, which always is integer. The format is 8.24. (The default value is <2 : 1>) |

#### 4.1.6.36 0x0148 DAC DRC Compressor Slope Low Setting Register (Default Value: 0x0000\_0000)

| Offset: 0x0148 |            |             | Register Name: AC_DAC_DRC_LKC                                                                                                                                                                                      |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                        |
| 31:16          | /          | /           | /                                                                                                                                                                                                                  |
| 15:0           | R/W        | 0x0000      | DAC_DRC_LKC<br>The slope of the compressor which determine by the equation that $Kc = 1/R$ , there, R is the ratio of the compressor, which always is interger. The format is 8.24. (The default value is <2 : 1>) |

#### 4.1.6.37 0x014C DAC DRC Compressor High Output at Compressor Threshold Register (Default Value: 0x0000\_F95B)

| Offset: 0x014C |            |             | Register Name: AC_DAC_DRC_HOPC                                                                                  |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                     |
| 31:16          | /          | /           | /                                                                                                               |
| 15:0           | R/W        | 0xF95B      | DAC_DRC_HOPC<br>The output of the compressor which determine by the equation $OPCin=OPC/6.0206$ . The format is |

| Offset: 0x014C |            |             | Register Name: AC_DAC_DRC_HOPC     |
|----------------|------------|-------------|------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                        |
|                |            |             | 8.24. (The default value is -40dB) |

4.1.6.38 0x0150 DAC DRC Compressor Low Output at Compressor Threshold Register (Default Value: 0x0000\_2C3F)

| Offset: 0x0150 |            |             | Register Name: AC_DAC_DRC_LOPC                                                                                                                  |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                     |
| 31:16          | /          | /           | /                                                                                                                                               |
| 15:0           | R/W        | 0x2C3F      | DAC_DRC_LOPC<br>The output of the compressor which determine by the equation OPCin=OPC/6.0206. The format is 8.24. (The default value is -40dB) |

4.1.6.39 0x0154 DAC DRC Limiter Threshold High Setting Register (Default Value: 0x0000\_01A9)

| Offset: 0x0154 |            |             | Register Name: AC_DAC_DRC_HLT                                                                                                                    |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                      |
| 31:16          | /          | /           | /                                                                                                                                                |
| 15:0           | R/W        | 0x01A9      | DAC_DRC_HLT<br>The limiter threshold setting, which set by the equation that LTin = -LT/6.0206. The format is 8.24. (The default value is -10dB) |

4.1.6.40 0x0158 DAC DRC Limiter Threshold Low Setting Register (Default Value: 0x0000\_34F0)

| Offset: 0x0158 |            |             | Register Name: AC_DAC_DRC_LLTD                                                                                                                    |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                       |
| 31:16          | /          | /           | /                                                                                                                                                 |
| 15:0           | R/W        | 0x34F0      | DAC_DRC_LLTD<br>The limiter threshold setting, which set by the equation that LTin = -LT/6.0206. The format is 8.24. (The default value is -10dB) |

4.1.6.41 0x015C DAC DRC Limiter Slope High Setting Register (Default Value: 0x0000\_0005)

| Offset: 0x015C |            |             | Register Name: AC_DAC_DRC_HKL |
|----------------|------------|-------------|-------------------------------|
| Bit            | Read/Write | Default/Hex | Description                   |
| 31:16          | /          | /           | /                             |

| Offset: 0x015C |            |             | Register Name: AC_DAC_DRC_HKL                                                                                                                                                                              |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                |
| 15:0           | R/W        | 0x0005      | DAC_DRC_HKL<br>The slope of the limiter which determine by the equation that $Kl = 1/R$ , there, R is the ratio of the limiter, which always is integer. The format is 8.24. (The default value is <50:1>) |

#### 4.1.6.42 0x0160 DAC DRC Limiter Slope Low Setting Register (Default Value: 0x0000\_1EB8)

| Offset: 0x0160 |            |             | Register Name: AC_DAC_DRC_LKL                                                                                                                                                                               |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                 |
| 31:16          | /          | /           | /                                                                                                                                                                                                           |
| 15:0           | R/W        | 0x1EB8      | DAC_DRC_LKL<br>The slope of the limiter which determine by the equation that $Kl = 1/R$ , there, R is the ratio of the limiter, which always is integer. The format is 8.24. (The default value is <50 :1>) |

#### 4.1.6.43 0x0164 DAC DRC Limiter High Output at Limiter Threshold (Default Value: 0x0000\_FBD8)

| Offset: 0x0164 |            |             | Register Name: AC_DAC_DRC_HOPL                                                                                                              |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                 |
| 31:16          | /          | /           | /                                                                                                                                           |
| 15:0           | R/W        | 0xFB8D      | DAC_DRC_HOPL<br>The output of the limiter which determine by equation $OPTin=OPT/6.0206$ . The format is 8.24. (The default value is -25dB) |

#### 4.1.6.44 0x0168 DAC DRC Limiter Low Output at Limiter Threshold (Default Value: 0x0000\_FBA7)

| Offset: 0x0168 |            |             | Register Name: AC_DAC_DRC_LOPL                                                                                                              |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                 |
| 31:16          | /          | /           | /                                                                                                                                           |
| 15:0           | R/W        | 0xFBA7      | DAC_DRC_LOPL<br>The output of the limiter which determine by equation $OPTin=OPT/6.0206$ . The format is 8.24. (The default value is -25dB) |

#### 4.1.6.45 0x016C DAC DRC Expander Threshold High Setting Register (Default Value: 0x0000\_0BA0)

| Offset: 0x016C |            |             | Register Name: AC_DAC_DRC_HET                                                                                                                     |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                       |
| 31:16          | /          | /           | /                                                                                                                                                 |
| 15:0           | R/W        | 0x0BA0      | DAC_DRC_HET<br>The expander threshold setting, which set by the equation that ETin = -ET/6.0206, The format is 8.24. (The default value is -70dB) |

#### 4.1.6.46 0x0170 DAC DRC Expander Threshold Low Setting Register (Default Value: 0x0000\_7291)

| Offset: 0x0170 |            |             | Register Name: AC_DAC_DRC_LET                                                                                                                     |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                       |
| 31:16          | /          | /           | /                                                                                                                                                 |
| 15:0           | R/W        | 0x7291      | DAC_DRC_LET<br>The expander threshold setting, which set by the equation that ETin = -ET/6.0206, The format is 8.24. (The default value is -70dB) |

#### 4.1.6.47 0x0174 DAC DRC Expander Slope High Setting Register (Default Value: 0x0000\_0500)

| Offset: 0x0174 |            |             | Register Name: AC_DAC_DRC_HKE                                                                                                                                                                                                           |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                             |
| 31:16          | /          | /           | /                                                                                                                                                                                                                                       |
| 15:0           | R/W        | 0x0500      | DAC_DRC_HKE<br>The slope of the expander which determine by the equation that Ke = 1/R, there, R is the ratio of the expander, which always is integer and the ke must larger than 50. The format is 8.24. (The default value is <1:5>) |

#### 4.1.6.48 0x0178 DAC DRC Expander Slope Low Setting Register (Default Value: 0x0000\_0000)

| Offset: 0x0178 |            |             | Register Name: AC_DAC_DRC_LKE                                                                                                                                          |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                            |
| 31:16          | /          | /           | /                                                                                                                                                                      |
| 15:0           | R/W        | 0x0000      | DAC_DRC_LKE<br>The slope of the expander which determine by the equation that Ke = 1/R, there, R is the ratio of the expander, which always is integer and the ke must |

| Offset: 0x0178 |            |             | Register Name: AC_DAC_DRC_LKE                                    |
|----------------|------------|-------------|------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                      |
|                |            |             | larger than 50. The format is 8.24. (The default value is <1:5>) |

#### 4.1.6.49 0x017C DAC DRC Expander High Output at Expander Threshold (Default Value: 0x0000\_F45F)

| Offset: 0x017C |            |             | Register Name: AC_DAC_DRC_HOPE                                                                                                            |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                               |
| 31:16          | /          | /           | /                                                                                                                                         |
| 15:0           | R/W        | 0xF45F      | DAC_DRC_HOPE<br>The output of the expander which determine by equation OPEin=OPE/6.0206. The format is 8.24. (The default value is -70dB) |

#### 4.1.6.50 0x0180 DAC DRC Expander Low Output at Expander Threshold (Default Value: 0x0000\_8D6E)

| Offset: 0x0180 |            |             | Register Name: AC_DAC_DRC_LOPE                                                                                                            |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                               |
| 31:16          | /          | /           | /                                                                                                                                         |
| 15:0           | R/W        | 0x8D6E      | DAC_DRC_LOPE<br>The output of the expander which determine by equation OPEin=OPE/6.0206. The format is 8.24. (The default value is -70dB) |

#### 4.1.6.51 0x0184 DAC DRC Linear Slope High Setting Register (Default Value: 0x0000\_0100)

| Offset: 0x0184 |            |             | Register Name: AC_DAC_DRC_HKN                                                                                                                                                                        |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                          |
| 31:16          | /          | /           | /                                                                                                                                                                                                    |
| 15:0           | R/W        | 0x0100      | DAC_DRC_HKN<br>The slope of the linear which determine by the equation that Kn = 1/R, there, R is the ratio of the linear, which always is integer. The format is 8.24. (The default value is <1:1>) |

#### 4.1.6.52 0x0188 DAC DRC Linear Slope Low Setting Register (Default Value: 0x0000\_0000)

| Offset: 0x0188 |            |             | Register Name: AC_DAC_DRC_LKN |
|----------------|------------|-------------|-------------------------------|
| Bit            | Read/Write | Default/Hex | Description                   |
| 31:16          | /          | /           | /                             |

| Offset: 0x0188 |            |             | Register Name: AC_DAC_DRC_LKN                                                                                                                                                                            |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                              |
| 15:0           | R/W        | 0x0000      | DAC_DRC_LKN<br>The slope of the linear which determine by the equation that $K_n = 1/R$ , there, R is the ratio of the linear, which always is integer. The format is 8.24. (The default value is <1:1>) |

4.1.6.53 0x018C DAC DRC Smooth Filter Gain High Attack Time Coef Register (Default Value: 0x0000\_0002)

| Offset: 0x018C |            |             | Register Name: AC_DAC_DRC_SFHAT                                                                                                                                                    |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                        |
| 31:11          | /          | /           | /                                                                                                                                                                                  |
| 10:0           | R/W        | 0x0002      | DAC_DRC_SFHAT<br>The smooth filter attack time parameter setting, which determine by the equation that $AT = 1 - \exp(-2.2Ts/tr)$ . The format is 3.24. (The default value is 5ms) |

4.1.6.54 0x0190 DAC DRC Smooth Filter Gain Low Attack Time Coef Register (Default Value: 0x0000\_5600)

| Offset: 0x0190 |            |             | Register Name: AC_DAC_DRC_SFLAT                                                                                                                                                    |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                        |
| 31:16          | /          | /           | /                                                                                                                                                                                  |
| 15:0           | R/W        | 0x5600      | DAC_DRC_SFLAT<br>The smooth filter attack time parameter setting, which determine by the equation that $AT = 1 - \exp(-2.2Ts/tr)$ . The format is 3.24. (The default value is 5ms) |

4.1.6.55 0x0194 DAC DRC Smooth Filter Gain High Release Time Coef Register (Default Value: 0x0000\_0000)

| Offset: 0x0194 |            |             | Register Name: AC_DAC_DRC_SFHRT                                                                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                       |
| 31:11          | /          | /           | /                                                                                                                 |
| 10:0           | R/W        | 0x0000      | DAC_DRC_SFHRT<br>The gain smooth filter release time parameter setting, which determine by the equation that $RT$ |

| Offset: 0x0194 |            |             | Register Name: AC_DAC_DRC_SFHRT                                      |
|----------------|------------|-------------|----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                          |
|                |            |             | = 1-exp(-2.2Ts/tr). The format is 3.24. (The default value is 200ms) |

4.1.6.56 0x0198 DAC DRC Smooth Filter Gain Low Release Time Coef Register (Default Value: 0x0000\_0F04)

| Offset: 0x0198 |            |             | Register Name: AC_DAC_DRC_SFLRT                                                                                                                                                      |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                          |
| 31:16          | /          | /           | /                                                                                                                                                                                    |
| 15:0           | R/W        | 0x0F04      | DAC_DRC_SFLRT<br>The gain smooth filter release time parameter setting, which determine by the equation that RT = 1-exp(-2.2Ts/tr). The format is 3.24. (The default value is 200ms) |

4.1.6.57 0x019C DAC DRC MAX Gain High Setting Register (Default Value: 0x0000\_FE56)

| Offset: 0x019C |            |             | Register Name: AC_DAC_DRC_MXGHS                                                                                                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                      |
| 31:16          | /          | /           | /                                                                                                                                                                |
| 15:0           | R/W        | 0xFE56      | DAC_DRC_MXGHS<br>The max gain setting which determine by equation MXGin=MXG/6.0206. The format is 8.24 and must -20dB < MXG < 30dB. (The default value is -10dB) |

4.1.6.58 0x01A0 DAC DRC MAX Gain Low Setting Register (Default Value: 0x0000\_CB0F)

| Offset: 0x01A0 |            |             | Register Name: AC_DAC_DRC_MXGLS                                                                                                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                      |
| 31:16          | /          | /           | /                                                                                                                                                                |
| 15:0           | R/W        | 0xCB0F      | DAC_DRC_MXGLS<br>The max gain setting which determine by equation MXGin=MXG/6.0206. The format is 8.24 and must -20dB < MXG < 30dB. (The default value is -10dB) |

**4.1.6.59 0x01A4 DAC DRC MIN Gain High Setting Register (Default Value: 0x0000\_F95B)**

| Offset: 0x01A4 |            |             | Register Name: AC_DAC_DRC_MNGHS                                                                                                                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                       |
| 31:16          | /          | /           | /                                                                                                                                                                 |
| 15:0           | R/W        | 0xF95B      | DAC_DRC_MNGHS<br>The min gain setting which determine by equation MNGin=MNG/6.0206. The format is 8.24 and must -60dB ≤ MNG ≤ -40dB. (The default value is -40dB) |

**4.1.6.60 0x01A8 DAC DRC MIN Gain Low Setting Register (Default Value: 0x0000\_2C3F)**

| Offset: 0x01A8 |            |             | Register Name: AC_DAC_DRC_MNGLS                                                                                                                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                       |
| 31:16          | /          | /           | /                                                                                                                                                                 |
| 15:0           | R/W        | 0x2C3F      | DAC_DRC_MNGLS<br>The min gain setting which determine by equation MNGin=MNG/6.0206. The format is 8.24 and must -60dB ≤ MNG ≤ -40dB. (The default value is -40dB) |

**4.1.6.61 0x01AC DAC DRC Expander Smooth Time High Coef Register (Default Value: 0x0000\_0000)**

| Offset: 0x01AC |            |             | Register Name: AC_DAC_DRC_EPSHC                                                                                                                                                                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                       |
| 31:11          | /          | /           | /                                                                                                                                                                                                                 |
| 10:0           | R/W        | 0x0000      | DAC_DRC_EPSHC<br>The gain smooth filter release and attack time parameter setting in expander region, which determine by the equation that RT = 1-exp(-2.2Ts/tr). The format is 3.24. (The default value is 30ms) |

**4.1.6.62 0x01B0 DAC DRC Expander Smooth Time Low Coef Register (Default Value: 0x0000\_640C)**

| Offset: 0x01B0 |            |             | Register Name: AC_DAC_DRC_EPSLC                                                                                                                 |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                     |
| 31:16          | /          | /           | /                                                                                                                                               |
| 15:0           | R/W        | 0x640C      | DAC_DRC_EPSLC<br>The gain smooth filter release and attack time parameter setting in expander region, which determine by the equation that RT = |

| Offset: 0x01B0 |            |             | Register Name: AC_DAC_DRC_EPSLC                                   |
|----------------|------------|-------------|-------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                       |
|                |            |             | 1-exp(-2.2Ts/tr). The format is 3.24. (The default value is 30ms) |

#### 4.1.6.63 0x01B8 DAC DRC HPF Gain High Coef Register (Default Value: 0x0000\_0100)

| Offset: 0x01B8 |            |             | Register Name: AC_DAC_DRC_HPFHGAIN                                                          |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                 |
| 31:11          | /          | /           | /                                                                                           |
| 10:0           | R/W        | 0x100       | DAC_DRC_HPFHGAIN<br>The gain of the HPF coefficient setting which format is 3.24.(gain = 1) |

#### 4.1.6.64 0x01BC DAC DRC HPF Gain Low Coef Register (Default Value: 0x0000\_0000)

| Offset: 0x01BC |            |             | Register Name: AC_DAC_DRC_HPFLGAIN                                                          |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                 |
| 31:16          | /          | /           | /                                                                                           |
| 15:0           | R/W        | 0x0000      | DAC_DRC_HPFLGAIN<br>The gain of the HPF coefficient setting which format is 3.24.(gain = 1) |

#### 4.1.6.65 0x0200 ADC DRC High HPF Coef Register (Default Value: 0x0000\_00FF)

| Offset: 0x0200 |            |             | Register Name: AC_ADC_DRC_HHPFC                                       |
|----------------|------------|-------------|-----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                           |
| 31:11          | /          | /           | /                                                                     |
| 10:0           | R/W        | 0xFF        | ADC_DRC_HHPFC<br>HPF coefficient setting and the data is 3.24 format. |

#### 4.1.6.66 0x0204 ADC DRC Low HPF Coef Register (Default Value: 0x0000\_FAC1)

| Offset: 0x0204 |            |             | Register Name: AC_ADC_DRC_LHPFC                                       |
|----------------|------------|-------------|-----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                           |
| 31:16          | /          | /           | /                                                                     |
| 15:0           | R/W        | 0xFAC1      | ADC_DRC_LHPFC<br>HPF coefficient setting and the data is 3.24 format. |

## 4.1.6.67 0x0208 ADC DRC Control Register (Default Value: 0x0000\_0080)

| Offset: 0x0208 |            |             | Register Name: AC_ADC_DRC_CTRL                                                                                                                                                                                                                                                                                 |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                    |
| 31:16          | /          | /           | /                                                                                                                                                                                                                                                                                                              |
| 15             | R          | 0x0         | ADC_DRC_DELAY_BUF_OUTPUT_STATE<br>DRC delay buffer data output state when DRC delay function is enable and the DRC function disable. After disable DRC function and this bit go to 0, the user should write the DRC delay function bit to 0;<br>0: not complete<br>1 : is complete                             |
| 14:10          | /          | /           | /                                                                                                                                                                                                                                                                                                              |
| 13:8           | R/W        | 0x0         | ADC_DRC_SIGNAL_DELAY_TIME_SET<br>Signal delay time setting<br>6'h00: (8x1) fs<br>6'h01: (8x2) fs<br>6'h02: (8x3) fs<br>-----<br>6'h2e: (8*47) fs<br>6'h2f: (8*48) fs<br>6'h30 -- 6'h3f: (8*48) fs<br>Delay time = 8*(n+1) fs, n<6'h30;<br>When the delay function is disable, the signal delay time is unused. |
| 7              | R/W        | 0x1         | ADC_DRC_DELAY_BUF_EN<br>The delay buffer use or not when the dry disable and the DRC buffer data output completely<br>0: don't use the buffer<br>1 : use the buffer                                                                                                                                            |
| 6              | R/W        | 0x0         | ADC_DRC_GAIN_MAX_LIMIT_EN<br>DRC gain max limit enable<br>0: disable<br>1 : enable                                                                                                                                                                                                                             |
| 5              | R/W        | 0x0         | ADC_DRC_GAIN_MIN_LIMIT_EN<br>DRC gain min limit enable. when this function enables, it will overwrite the noise detect function.<br>0: disable<br>1 : enable                                                                                                                                                   |
| 4              | R/W        | 0x0         | ADC_DRC_DETECT_NOISE_EN<br>Control the DRC to detect noise when ET enable                                                                                                                                                                                                                                      |

| Offset: 0x0208 |            |             | Register Name: AC_ADC_DRC_CTRL                                                                                                                                                                                                                                                                                                                                                                                                                    |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                |            |             | 0: disable<br>1 : enable                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 3              | R/W        | 0x0         | ADC_DRC_SIGNAL_FUNC_SEL<br>Signal function Select<br>0: RMS filter<br>1: Peak filter<br>When signal function selects Peak filter, the RMS parameter is unused. (AC_DRC_LRMSHAT / AC_DRC_LRMSLAT / AC_DRC_LRMSHAT / AC_DRC_LRMSLAT)<br>When Signal function Select RMS filter, the Peak filter parameter is unused.(AC_DRC_LPFHAT / AC_DRC_LPFLAT / AC_DRC_RPFHAT / AC_DRC_RPFLAT / AC_DRC_LPFHRT / AC_DRC_LPFLRT / AC_DRC_RPFHRT / AC_DRC_RPFLRT) |
| 2              | R/W        | 0x0         | ADC_DRC_DELAY_FUNC_EN<br>Delay function enable<br>0: disable<br>1: enable<br>When the Delay function enable is disable, the Signal delay time is unused.                                                                                                                                                                                                                                                                                          |
| 1              | R/W        | 0x0         | ADC_DRC_LT_EN<br>DRC LT enable<br>0: disable<br>1: enable<br>DRC LT enable<br>0: disable<br>1: enable<br>When the DRC LT is disable the LT, Kl and OPL parameter is unused.                                                                                                                                                                                                                                                                       |
| 0              | R/W        | 0x0         | ADC_DRC_ET_EN<br>DRC ET enable<br>0: disable<br>1: enable<br>When the DRC ET is disable the ET, Ke and OPE parameter is unused.                                                                                                                                                                                                                                                                                                                   |

#### 4.1.6.68 0x020C ADC DRC Left Peak Filter High Attack Time Coef Register (Default Value: 0x0000\_000B)

| Offset: 0x020C | Register Name: AC_ADC_DRC_LPFHAT |
|----------------|----------------------------------|
|----------------|----------------------------------|

| Bit   | Read/Write | Default/Hex | Description                                                                                                                                                                            |
|-------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:11 | /          | /           | /                                                                                                                                                                                      |
| 10:0  | R/W        | 0x000B      | ADC_DRC_LPFHAT<br>The left peak filter attack time parameter setting, which determine by the equation that AT = $1 - \exp(-2.2Ts/ta)$ . The format is 3.24. (The default value is 1ms) |

#### 4.1.6.69 0x0210 ADC DRC Left Peak Filter Low Attack Time Coef Register (Default Value: 0x0000\_77BF)

| Offset: 0x0210 |            |             | Register Name: AC_ADC_DRC_LPFLAT                                                                                                                                                       |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                            |
| 31:16          | /          | /           | /                                                                                                                                                                                      |
| 15:0           | R/W        | 0x77BF      | ADC_DRC_LPFLAT<br>The left peak filter attack time parameter setting, which determine by the equation that AT = $1 - \exp(-2.2Ts/ta)$ . The format is 3.24. (The default value is 1ms) |

#### 4.1.6.70 0x0214 ADC DRC Right Peak Filter High Attack Time Coef Register (Default Value: 0x0000\_000B)

| Offset: 0x0214 |            |             | Register Name: AC_ADC_DRC_RPFHAT                                                                                                                                                        |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                             |
| 31:16          | /          | /           | /                                                                                                                                                                                       |
| 15:0           | R/W        | 0x000B      | ADC_DRC_RPFHAT<br>The right peak filter attack time parameter setting, which determine by the equation that AT = $1 - \exp(-2.2Ts/ta)$ . The format is 3.24. (The default value is 1ms) |

#### 4.1.6.71 0x0218 ADC DRC Right Peak Filter Low Attack Time Coef Register (Default Value: 0x0000\_77BF)

| Offset: 0x0218 |            |             | Register Name: AC_ADC_DRC_RPFLAT                                                                                                                                                       |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                            |
| 31:16          | /          | /           | /                                                                                                                                                                                      |
| 15:0           | R/W        | 0x77BF      | ADC_DRC_RPFLAT<br>The right peak filter attack time parameter setting, which determine by the equation that AT = $1 - \exp(-2.2Ts/ta)$ . The format is 3.24.(The default value is 1ms) |

## 4.1.6.72 0x021C ADC DRC Left Peak Filter High Release Time Coef Register (Default Value: 0x0000\_00FF)

| Offset: 0x021C |            |             | Register Name: AC_ADC_DRC_LPFHRT                                                                                                                                                  |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                       |
| 31:11          | /          | /           | /                                                                                                                                                                                 |
| 10:0           | R/W        | 0x00FF      | ADC_DRC_LPFHRT<br>The left peak filter release time parameter setting, which determine by the equation that RT = exp(-2.2Ts/tr). The format is 3.24. (The default value is 100ms) |

## 4.1.6.73 0x0220 ADC DRC Left Peak Filter Low Release Time Coef Register (Default Value: 0x0000\_E1F8)

| Offset: 0x0220 |            |             | Register Name: AC_ADC_DRC_LPFLRT                                                                                                                                                  |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                       |
| 31:16          | /          | /           | /                                                                                                                                                                                 |
| 15:0           | R/W        | 0xE1F8      | ADC_DRC_LPFLRT<br>The left peak filter release time parameter setting, which determine by the equation that RT = exp(-2.2Ts/tr). The format is 3.24. (The default value is 100ms) |

## 4.1.6.74 0x0224 ADC DRC Right Peak filter High Release Time Coef Register (Default Value: 0x0000\_00FF)

| Offset: 0x0224 |            |             | Register Name: AC_ADC_DRC_RPFHRT                                                                                                                                                  |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                       |
| 31:16          | /          | /           | /                                                                                                                                                                                 |
| 15:0           | R/W        | 0x00FF      | ADC_DRC_RPFHRT<br>The right peak filter attack time parameter setting, which determine by the equation that RT = exp(-2.2Ts/tr). The format is 3.24. (The default value is 100ms) |

## 4.1.6.75 0x0228 ADC DRC Right Peak Filter Low Release Time Coef Register (Default Value: 0x0000\_E1F8)

| Offset: 0x0228 |            |             | Register Name: AC_ADC_DRC_RPFLRT                                                                                |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                     |
| 31:16          | /          | /           | /                                                                                                               |
| 15:0           | R/W        | 0xE1F8      | ADC_DRC_RPFLRT<br>The right peak filter release time parameter setting, which determine by the equation that AT |

| Offset: 0x0228 |            |             | Register Name: AC_ADC_DRC_RPFLRT                                   |
|----------------|------------|-------------|--------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                        |
|                |            |             | = exp(-2.2Ts/tr). The format is 3.24. (The default value is 100ms) |

#### 4.1.6.76 0x022C ADC DRC Left RMS Filter High Coef Register (Default Value: 0x0000\_0001)

| Offset: 0x022C |            |             | Register Name: AC_ADC_DRC_LRMSHAT                                                                                                                                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                         |
| 31:11          | /          | /           | /                                                                                                                                                                                   |
| 10:0           | R/W        | 0x0001      | ADC_DRC_LRMSHAT<br>The left RMS filter average time parameter setting, which determine by the equation that AT = 1-exp(-2.2Ts/tav). The format is 3.24. (The default value is 10ms) |

#### 4.1.6.77 0x0230 ADC DRC Left RMS Filter Low Coef Register (Default Value: 0x0000\_2BAF)

| Offset: 0x0230 |            |             | Register Name: AC_ADC_DRC_LRMSLAT                                                                                                                                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                         |
| 31:16          | /          | /           | /                                                                                                                                                                                   |
| 15:0           | R/W        | 0x2BAF      | ADC_DRC_LRMSLAT<br>The left RMS filter average time parameter setting, which determine by the equation that AT = 1-exp(-2.2Ts/tav). The format is 3.24. (The default value is 10ms) |

#### 4.1.6.78 0x0234 ADC DRC Right RMS Filter High Coef Register (Default Value: 0x0000\_0001)

| Offset: 0x0234 |            |             | Register Name: AC_ADC_DRC_RRMSHAT                                                                                                                                                    |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                          |
| 31:16          | /          | /           | /                                                                                                                                                                                    |
| 15:0           | R/W        | 0x0001      | ADC_DRC_RRMSHAT<br>The right RMS filter average time parameter setting, which determine by the equation that AT = 1-exp(-2.2Ts/tav). The format is 3.24. (The default value is 10ms) |

#### 4.1.6.79 0x0238 ADC DRC Right RMS Filter Low Coef Register (Default Value: 0x0000\_2BAF)

|                |                                   |
|----------------|-----------------------------------|
| Offset: 0x0238 | Register Name: AC_ADC_DRC_RRMSLAT |
|----------------|-----------------------------------|

| Bit   | Read/Write | Default/Hex | Description                                                                                                                                                                          |
|-------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | /          | /           | /                                                                                                                                                                                    |
| 15:0  | R/W        | 0x2BAF      | ADC_DRC_RRMSLAT<br>The right RMS filter average time parameter setting, which determine by the equation that AT = 1-exp(-2.2Ts/tav). The format is 3.24. (The default value is 10ms) |

#### 4.1.6.80 0x023C ADC DRC Compressor Threshold High Setting Register (Default Value: 0x0000\_06A4)

| Offset: 0x023C |            |             | Register Name: AC_ADC_DRC_HCT                                                                                                                       |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                         |
| 31:16          | /          | /           | /                                                                                                                                                   |
| 15:0           | R/W        | 0x06A4      | ADC_DRC_HCT<br>The compressor threshold setting, which set by the equation that CTin = -CT/6.0206. The format is 8.24. (The default value is -40dB) |

#### 4.1.6.81 0x0240 ADC DRC Compressor Slope High Setting RegisterB (Default Value: 0x0000\_D3C0)

| Offset: 0x0240 |            |             | Register Name: AC_ADC_DRC_LCT                                                                                                                       |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                         |
| 31:16          | /          | /           | /                                                                                                                                                   |
| 15:0           | R/W        | 0xD3C0      | ADC_DRC_LCT<br>The compressor threshold setting, which set by the equation that CTin = -CT/6.0206. The format is 8.24. (The default value is -40dB) |

#### 4.1.6.82 0x0244 ADC DRC Compressor Slope High Setting Register (Default Value: 0x0000\_0080)

| Offset: 0x0244 |            |             | Register Name: AC_ADC_DRC_HKC                                                                                                                                                                                  |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                    |
| 31:16          | /          | /           | /                                                                                                                                                                                                              |
| 15:0           | R/W        | 0x0080      | ADC_DRC_HKC<br>The slope of the compressor which determine by the equation that Kc = 1/R, there, R is the ratio of the compressor, which always is integer. The format is 8.24. (The default value is <2 : 1>) |

#### 4.1.6.83 0x0248 ADC DRC Compressor Slope Low Setting Register (Default Value: 0x0000\_0000)

| Offset: 0x0248 |            |             | Register Name: AC_ADC_DRC_LKC                                                                                                                                                                                      |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                        |
| 31:16          | /          | /           | /                                                                                                                                                                                                                  |
| 15:0           | R/W        | 0x0000      | ADC_DRC_LKC<br>The slope of the compressor which determine by the equation that $K_c = 1/R$ , there, R is the ratio of the compressor, which always is integer. The format is 8.24. (The default value is <2 : 1>) |

#### 4.1.6.84 0x024C ADC DRC Compressor High Output at Compressor Threshold Register (Default Value: 0x0000\_F95B)

| Offset: 0x024C |            |             | Register Name: AC_ADC_DRC_HOPC                                                                                                                          |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                             |
| 31:16          | /          | /           | /                                                                                                                                                       |
| 15:0           | R/W        | 0xF95B      | ADC_DRC_HOPC<br>The output of the compressor which determine by the equation $OPC_{in} = OPC/6.0206$ . The format is 8.24. (The default value is -40dB) |

#### 4.1.6.85 ADC DRC Compressor Low Output at Compressor Threshold Register (Default Value: 0x0250 0x0000\_2C3F)

| Offset: 0x0250 |            |             | Register Name: AC_ADC_DRC_LOPC                                                                                                                          |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                             |
| 31:16          | /          | /           | /                                                                                                                                                       |
| 15:0           | R/W        | 0x2C3F      | ADC_DRC_LOPC<br>The output of the compressor which determine by the equation $OPC_{in} = OPC/6.0206$ . The format is 8.24. (The default value is -40dB) |

#### 4.1.6.86 0x0254 ADC DRC Limiter Threshold High Setting Register (Default Value: 0x0000\_01A9)

| Offset: 0x0254 |            |             | Register Name: AC_ADC_DRC_HLT                                                                                       |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                         |
| 31:16          | /          | /           | /                                                                                                                   |
| 15:0           | R/W        | 0x01A9      | ADC_DRC_HLT<br>The limiter threshold setting, which set by the equation that $LT_{in} = -LT/6.0206$ . The format is |

| Offset: 0x0254 |            |             | Register Name: AC_ADC_DRC_HLT      |
|----------------|------------|-------------|------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                        |
|                |            |             | 8.24. (The default value is -10dB) |

#### 4.1.6.87 0x0258 ADC DRC Limiter Threshold Low Setting Register (Default Value: 0x0000\_34F0)

| Offset: 0x0258 |            |             | Register Name: AC_ADC_DRC_LLT                                                                                                                    |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                      |
| 31:16          | /          | /           | /                                                                                                                                                |
| 15:0           | R/W        | 0x34F0      | ADC_DRC_LLT<br>The limiter threshold setting, which set by the equation that LTin = -LT/6.0206. The format is 8.24. (The default value is -10dB) |

#### 4.1.6.88 0x025C ADC DRC Limiter Slope High Setting Register (Default Value: 0x0000\_0005)

| Offset: 0x025C |            |             | Register Name: AC_ADC_DRC_HKI                                                                                                                                                                           |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                             |
| 31:16          | /          | /           | /                                                                                                                                                                                                       |
| 15:0           | R/W        | 0x0005      | ADC_DRC_HKI<br>The slope of the limiter which determine by the equation that KI = 1/R, there, R is the ratio of the limiter, which always is integer. The format is 8.24. (The default value is <50:1>) |

#### 4.1.6.89 0x0260 ADC DRC Limiter Slope Low Setting Register (Default Value: 0x0000\_1EB8)

| Offset: 0x0260 |            |             | Register Name: AC_ADC_DRC_LKI                                                                                                                                                                           |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                             |
| 31:16          | /          | /           | /                                                                                                                                                                                                       |
| 15:0           | R/W        | 0x1EB8      | ADC_DRC_LKI<br>The slope of the limiter which determine by the equation that KI = 1/R, there, R is the ratio of the limiter, which always is integer. The format is 8.24. (The default value is <50:1>) |

#### 4.1.6.90 0x0264 ADC DRC Limiter High Output at Limiter Threshold (Default Value: 0x0000\_FBD8)

| Offset: 0x0264 |            |             | Register Name: AC_ADC_DRC_HOPL |
|----------------|------------|-------------|--------------------------------|
| Bit            | Read/Write | Default/Hex | Description                    |
| 31:16          | /          | /           | /                              |

| Offset: 0x0264 |            |             | Register Name: AC_ADC_DRC_HOPL                                                                                                           |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                              |
| 15:0           | R/W        | 0xFBD8      | ADC_DRC_HOPL<br>The output of the limiter which determine by equation OPTin=OPT/6.0206. The format is 8.24. (The default value is -25dB) |

#### 4.1.6.91 0x0268 ADC DRC Limiter Low Output at Limiter Threshold (Default Value: 0x0000\_FBA7)

| Offset: 0x0268 |            |             | Register Name: AC_ADC_DRC_LOPL                                                                                                           |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                              |
| 31:16          | /          | /           | /                                                                                                                                        |
| 15:0           | R/W        | 0xFBA7      | ADC_DRC_LOPL<br>The output of the limiter which determine by equation OPTin=OPT/6.0206. The format is 8.24. (The default value is -25dB) |

#### 4.1.6.92 0x026C ADC DRC Expander Threshold High Setting Register (Default Value: 0x0000\_0BA0)

| Offset: 0x026C |            |             | Register Name: AC_ADC_DRC_HET                                                                                                                     |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                       |
| 31:16          | /          | /           | /                                                                                                                                                 |
| 15:0           | R/W        | 0x0BA0      | ADC_DRC_HET<br>The expander threshold setting, which set by the equation that ETin = -ET/6.0206. The format is 8.24. (The default value is -70dB) |

#### 4.1.6.93 0x0270 ADC DRC Expander Threshold Low Setting Register (Default Value: 0x0000\_7291)

| Offset: 0x0270 |            |             | Register Name: AC_ADC_DRC_LET                                                                                                                     |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                       |
| 31:16          | /          | /           | /                                                                                                                                                 |
| 15:0           | R/W        | 0x7291      | ADC_DRC_LET<br>The expander threshold setting, which set by the equation that ETin = -ET/6.0206. The format is 8.24. (The default value is -70dB) |

#### 4.1.6.94 0x0274 ADC DRC Expander Slope High Setting Register (Default Value: 0x0000\_0500)

| Offset: 0x0274 |            |             | Register Name: AC_ADC_DRC_HKE |
|----------------|------------|-------------|-------------------------------|
| Bit            | Read/Write | Default/Hex | Description                   |

| Offset: 0x0274 |            |             | Register Name: AC_ADC_DRC_HKE                                                                                                                                                                                                              |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                |
| 31:16          | /          | /           | /                                                                                                                                                                                                                                          |
| 15:0           | R/W        | 0x0500      | ADC_DRC_HKE<br>The slope of the expander which determine by the equation that $Ke = 1/R$ , there, R is the ratio of the expander, which always is integer and the ke must larger than 50. The format is 8.24. (The default value is <1:5>) |

#### 4.1.6.95 0x0278 ADC DRC Expander Slope Low Setting Register (Default Value: 0x0000\_0000)

| Offset: 0x0278 |            |             | Register Name: AC_ADC_DRC_LKE                                                                                                                                                                                                              |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                |
| 31:16          | /          | /           | /                                                                                                                                                                                                                                          |
| 15:0           | R/W        | 0x0000      | ADC_DRC_LKE<br>The slope of the expander which determine by the equation that $Ke = 1/R$ , there, R is the ratio of the expander, which always is integer and the ke must larger than 50. The format is 8.24. (The default value is <1:5>) |

#### 4.1.6.96 0x027C ADC DRC Expander High Output at Expander Threshold (Default Value: 0x0000F45F)

| Offset: 0x027C |            |             | Register Name: AC_ADC_DRC_HOPE                                                                                                               |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                  |
| 31:16          | /          | /           | /                                                                                                                                            |
| 15:0           | R/W        | 0xF45F      | ADC_DRC_HOPE<br>The output of the expander which determine by equation $OPEin=OPE/6.0206$ . The format is 8.24. (The default value is -70dB) |

#### 4.1.6.97 0x0280 ADC DRC Expander Low Output at Expander Threshold (Default Value: 0x0000\_8D6E)

| Offset: 0x0280 |            |             | Register Name: AC_ADC_DRC_LOPE                                                                                                               |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                  |
| 31:16          | /          | /           | /                                                                                                                                            |
| 15:0           | R/W        | 0x8D6E      | ADC_DRC_LOPE<br>The output of the expander which determine by equation $OPEin=OPE/6.0206$ . The format is 8.24. (The default value is -70dB) |

**4.1.6.98 0x0284 ADC DRC Linear Slope High Setting Register (Default Value: 0x0000\_0100)**

| Offset: 0x0284 |            |             | Register Name: AC_ADC_DRC_HKN                                                                                                                                                                            |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                              |
| 31:16          | /          | /           | /                                                                                                                                                                                                        |
| 15:0           | R/W        | 0x0100      | ADC_DRC_HKN<br>The slope of the linear which determine by the equation that $K_n = 1/R$ , there, R is the ratio of the linear, which always is integer. The format is 8.24. (The default value is <1:1>) |

**4.1.6.99 0x0288 ADC DRC Linear Slope Low Setting Register (Default Value: 0x0000\_0000)**

| Offset: 0x0288 |            |             | Register Name: AC_ADC_DRC_LKN                                                                                                                                                                            |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                              |
| 31:16          | /          | /           | /                                                                                                                                                                                                        |
| 15:0           | R/W        | 0x0000      | ADC_DRC_LKN<br>The slope of the linear which determine by the equation that $K_n = 1/R$ , there, R is the ratio of the linear, which always is integer. The format is 8.24. (The default value is <1:1>) |

**4.1.6.100 0x028C ADC DRC Smooth Filter Gain High Attack Time Coef Register (Default Value: 0x0000\_0002)**

| Offset: 0x028C |            |             | Register Name: AC_ADC_DRC_SFHAT                                                                                                                                                    |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                        |
| 31:11          | /          | /           | /                                                                                                                                                                                  |
| 10:0           | R/W        | 0x0002      | ADC_DRC_SFHAT<br>The smooth filter attack time parameter setting, which determine by the equation that $AT = 1 - \exp(-2.2Ts/tr)$ . The format is 3.24. (The default value is 5ms) |

**4.1.6.101 0x0290 ADC DRC Smooth Filter Gain Low Attack Time Coef Register (Default Value: 0x0000\_5600)**

| Offset: 0x0290 |            |             | Register Name: AC_ADC_DRC_SFLAT |
|----------------|------------|-------------|---------------------------------|
| Bit            | Read/Write | Default/Hex | Description                     |
| 31:16          | /          | /           | /                               |
| 15:0           | R/W        | 0x5600      | ADC_DRC_SFLAT                   |

| Offset: 0x0290 |            |             | Register Name: AC_ADC_DRC_SFLAT                                                                                                                             |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                 |
|                |            |             | The smooth filter attack time parameter setting, which determine by the equation that AT = 1-exp(-2.2Ts/tr). The format is 3.24. (The default value is 5ms) |

4.1.6.102 0x0294 ADC DRC Smooth Filter Gain High Release Time Coef Register (Default Value: 0x0000\_0000)

| Offset: 0x0294 |            |             | Register Name: AC_ADC_DRC_SFHRT                                                                                                                                                      |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                          |
| 31:11          | /          | /           | /                                                                                                                                                                                    |
| 10:0           | R/W        | 0x0000      | ADC_DRC_SFHRT<br>The gain smooth filter release time parameter setting, which determine by the equation that RT = 1-exp(-2.2Ts/tr). The format is 3.24. (The default value is 200ms) |

4.1.6.103 0x0298 ADC DRC Smooth Filter Gain Low Release Time Coef Register (Default Value: 0x0000\_0F04)

| Offset: 0x0298 |            |             | Register Name: AC_ADC_DRC_SFLRT                                                                                                                                                      |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                          |
| 31:16          | /          | /           | /                                                                                                                                                                                    |
| 15:0           | R/W        | 0x0F04      | ADC_DRC_SFLRT<br>The gain smooth filter release time parameter setting, which determine by the equation that RT = 1-exp(-2.2Ts/tr). The format is 3.24. (The default value is 200ms) |

4.1.6.104 0x029C ADC DRC MAX Gain High Setting Register (Default Value: 0x0000\_FE56)

| Offset: 0x029C |            |             | Register Name: AC_ADC_DRC_MXGHS                                                                                                                                 |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                     |
| 31:16          | /          | /           | /                                                                                                                                                               |
| 15:0           | R/W        | 0xFE56      | ADC_DRC_MXGHS<br>The max gain setting which determine by equation MXGin=MXG/6.0206. The format is 8.24 and must -20dB < MXG < 30dB (The default value is -10dB) |

**4.1.6.105 0x02A0 ADC DRC MAX Gain Low Setting Register (Default Value: 0x0000\_CB0F)**

| Offset: 0x02A0 |            |             | Register Name: AC_ADC_DRC_MXGLS                                                                                                                                 |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                     |
| 31:16          | /          | /           | /                                                                                                                                                               |
| 15:0           | R/W        | 0xCB0F      | ADC_DRC_MXGLS<br>The max gain setting which determine by equation MXGin=MXG/6.0206. The format is 8.24 and must -20dB < MXG < 30dB (The default value is -10dB) |

**4.1.6.106 0x02A4 ADC DRC MIN Gain High Setting Register (Default Value: 0x0000\_F95B)**

| Offset: 0x02A4 |            |             | Register Name: AC_ADC_DRC_MNGHS                                                                                                                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                       |
| 31:16          | /          | /           | /                                                                                                                                                                 |
| 15:0           | R/W        | 0xF95B      | ADC_DRC_MNGHS<br>The min gain setting which determine by equation MNGin=MNG/6.0206. The format is 8.24 and must -60dB ≤ MNG ≤ -40dB. (The default value is -40dB) |

**4.1.6.107 0x02A8 ADC DRC MIN Gain Low Setting Register (Default Value: 0x0000\_2C3F)**

| Offset: 0x02A8 |            |             | Register Name: AC_ADC_DRC_MNGLS                                                                                                                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                       |
| 31:16          | /          | /           | /                                                                                                                                                                 |
| 15:0           | R/W        | 0x2C3F      | ADC_DRC_MNGLS<br>The min gain setting which determine by equation MNGin=MNG/6.0206. The format is 8.24 and must -60dB ≤ MNG ≤ -40dB. (The default value is -40dB) |

**4.1.6.108 0x02AC ADC DRC Expander Smooth Time High Coef Register (Default Value: 0x0000\_0000)**

| Offset: 0x02AC |            |             | Register Name: AC_ADC_DRC_EPSHC                                                                                                                                                                    |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                        |
| 31:11          | /          | /           | /                                                                                                                                                                                                  |
| 10:0           | R/W        | 0x0000      | ADC_DRC_EPSHC<br>The gain smooth filter release and attack time parameter setting in expander region, which determine by the equation that RT = 1-exp(-2.2Ts/tr). The format is 3.24. (The default |

| Offset: 0x02AC |            |             | Register Name: AC_ADC_DRC_EPSHC |
|----------------|------------|-------------|---------------------------------|
| Bit            | Read/Write | Default/Hex | Description                     |
|                |            |             | value is 30ms)                  |

#### 4.1.6.109 0x02B0 ADC DRC Expander Smooth Time Low Coef Register (Default Value: 0x0000\_640C)

| Offset: 0x02B0 |            |             | Register Name: AC_ADC_DRC_EPSLC                                                                                                                                                                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                       |
| 31:16          | /          | /           | /                                                                                                                                                                                                                 |
| 15:0           | R/W        | 0x640C      | ADC_DRC_EPSLC<br>The gain smooth filter release and attack time parameter setting in expander region, which determine by the equation that RT = 1-exp(-2.2Ts/tr). The format is 3.24. (The default value is 30ms) |

#### 4.1.6.110 0x02B8 ADC DRC HPF Gain High Coef Register (Default Value: 0x0000\_0100)

| Offset: 0x02B8 |            |             | Register Name: AC_ADC_DRC_HPFHGAIN                                                          |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                 |
| 31:11          | /          | /           | /                                                                                           |
| 10:0           | R/W        | 0x100       | ADC_DRC_HPFHGAIN<br>The gain of the HPF coefficient setting which format is 3.24.(gain = 1) |

#### 4.1.6.111 0x02BC ADC DRC HPF Gain Low Coef Register (Default Value: 0x0000\_0000)

| Offset: 0x02BC |            |             | Register Name: AC_ADC_DRC_HPFLGAIN                                                          |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                 |
| 31:16          | /          | /           | /                                                                                           |
| 15:0           | R/W        | 0x0000      | ADC_DRC_HPFLGAIN<br>The gain of the HPF coefficient setting which format is 3.24.(gain = 1) |

#### 4.1.6.112 0x0300 ADC1 Analog Control Register (Default Value:0x001C\_C055)

| Offset: 0x0300 |     |         | Register Name: ADC1_REG                      |
|----------------|-----|---------|----------------------------------------------|
| Bit            | R/W | Default | Description                                  |
| 31             | R/W | 0x0     | ADC1_EN<br>ADC1 Channel Enable<br>0: Disable |

| Offset: 0x0300 |     |         | Register Name: ADC1_REG                                                                                                                                      |
|----------------|-----|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | R/W | Default | Description                                                                                                                                                  |
|                |     |         | 1: Enable<br>MIC1_PGA_EN<br>MIC1 PGA Enable<br>0: Disable<br>1: Enable                                                                                       |
| 30             | R/W | 0x0     | MIC1_PGA_EN<br>MIC1 PGA Enable<br>0: Disable<br>1: Enable                                                                                                    |
| 29             | R/W | 0x0     | ADC1 Dither Control<br>0: New Dither Off<br>1: New Dither On                                                                                                 |
| 28:26          | R/W | 0x0     | /                                                                                                                                                            |
| 25:24          | R/W | 0x0     | DSM_DITHER_LVL<br>Dither Level Control (Dither level is positive related to the ctrl bits)<br>0: No Level<br>1: Min Level<br>2: Middle Level<br>3: Max Level |
| 23:22          | R/W | 0x0     | /                                                                                                                                                            |
| 21:20          | R/W | 0x1     | ADC1_OUTPUT_CURRENT<br>ADC1 high gain OP Output Current Select<br>00: 15I<br>01: 20I<br>10: 35I<br>11: 40I<br>I=7uA                                          |
| 19:18          | R/W | 0x3     | ADC1_PGA_CTRL_RCM<br>ADC1 PGA Common Mode Input Impedance Control for MIC<br>0: 100 kΩ<br>1: 75 kΩ<br>2: 50 kΩ<br>3: 25 kΩ                                   |
| 17:16          | R/W | 0x0     | ADC1_PGA_IN_VCM_CTRL<br>ADC1 PGA Common-Mode Voltage Control<br>0: 900mV<br>1: 800mV<br>2: 750mV<br>3: 700mV                                                 |
| 15:14          | R/W | 0x3     | IOPADC<br>ADC1-ADC3 Bias Current Select<br>00: 1uA<br>01: 2uA                                                                                                |

| Offset: 0x0300 |     |         | Register Name: ADC1_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|----------------|-----|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | R/W | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                |     |         | 10: 3uA<br>11: 4uA                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 13             | R/W | 0x0     | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 12:8           | R/W | 0x0     | ADC1_PGA_GAIN_CTRL<br>ADC1 PGA gain settings:<br>0x0: 0 dB 0x10: 21 dB<br>0x1: 6 dB 0x11: 22 dB<br>0x2: 6 dB 0x12: 23 dB<br>0x3: 6 dB 0x13: 24 dB<br>0x4: 9 dB 0x14: 25 dB<br>0x5: 10 dB 0x15: 26 dB<br>0x6: 11 dB 0x16: 27 dB<br>0x7: 12 dB 0x17: 28 dB<br>0x8: 13 dB 0x18: 29 dB<br>0x9: 14 dB 0x19: 30 dB<br>0xA: 15 dB 0x1A: 31 dB<br>0xB: 16 dB 0x1B: 32 dB<br>0xC: 17 dB 0x1C: 33 dB<br>0xD: 18 dB 0x1D: 34 dB<br>0xE: 19 dB 0x1E: 35 dB<br>0xF: 20 dB 0x1F: 36 dB |
| 7:6            | R/W | 0x1     | ADC1_IOPAAF<br>ADC1 OP AAF Bias Current Select<br>00: 1.50*IOPADC<br>01: 1.75*IOPADC<br>10: 2.00*IOPADC<br>11: 2.25*IOPADC<br><br>IOPADC is defined by ADC1_REG<15:14> from 1uA to 4uA<br>For example:<br>ADC1_REG<15:14>=11, IOPADC=4uA<br>00: 1.50*4uA=6uA<br>01: 1.75*4uA=7uA<br>10: 2.00*4uA=8uA<br>11: 2.25*4uA=9uA                                                                                                                                                 |
| 5:4            | R/W | 0x1     | ADC1_IOPSMD1<br>ADC1 OP SDM Bias Current Select 1<br>00: 1.50*IOPADC<br>01: 1.75*IOPADC<br>10: 2.00*IOPADC<br>11: 2.25*IOPADC<br><br>IOPADC is defined by ADC1_REG<15:14> from 1uA to 4uA                                                                                                                                                                                                                                                                                |

| Offset: 0x0300 |     |         | Register Name: ADC1_REG                                                                                                                                                               |
|----------------|-----|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | R/W | Default | Description                                                                                                                                                                           |
| 3:2            | R/W | 0x1     | ADC1_IOPSDM2<br>ADC1 OP SDM Bias Current Select 2<br>00: 1.50*IOPADC<br>01: 1.75*IOPADC<br>10: 2.00*IOPADC<br>11: 2.25*IOPADC<br>IOPADC is defined by ADC1_REG<15:14> from 1uA to 4uA |
| 1:0            | R/W | 0x1     | ADC1_IOPMIC<br>ADC1 OP MIC Bias Current Select<br>00: 1.50*IOPADC<br>01: 1.75*IOPADC<br>10: 2.00*IOPADC<br>11: 2.25*IOPADC<br>IOPADC is defined by ADC1_REG<15:14> from 1uA to 4uA    |

#### 4.1.6.113 0x0304 ADC2 Analog Control Register (Default Value:0x001C\_0055)

| Offset: 0x0304 |     |         | Register Name: ADC2_REG                                                                                                                                     |
|----------------|-----|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | R/W | Default | Description                                                                                                                                                 |
| 31             | R/W | 0x0     | ADC2_EN<br>ADC2 Channel Enable<br>0: Disable<br>1: Enable                                                                                                   |
| 30             | R/W | 0x0     | MIC2_PGA_EN<br>MIC2 PGA Enable<br>0: Disable<br>1: Enable                                                                                                   |
| 29             | R/W | 0x0     | ADC2 Dither Control<br>0: New Dither Off<br>1: New Dither On                                                                                                |
| 28:26          | R/W | 0x0     | /                                                                                                                                                           |
| 25:24          | R/W | 0x0     | DSM_DITHER_LVL<br>Dither Level Control (Dither level is positive related to the ctrl bits)<br>0: No Level<br>1: Min Level<br>2: Middle Level<br>3:Max Level |
| 23:22          | R/W | 0x0     | /                                                                                                                                                           |
| 21:20          | R/W | 0x1     | ADC2_OUTPUT_CURRENT<br>ADC2 high gain OP Output Current Select                                                                                              |

| Offset: 0x0304 |     |         | Register Name: ADC2_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------------|-----|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | R/W | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                |     |         | 00: 15I<br>01: 20I<br>10: 35I<br>11: 40I<br>I=7uA                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 19:18          | R/W | 0x3     | <b>ADC2_PGA_CTRL_RCM</b><br>ADC2 PGA Common Mode Input Impedance Control for MICIN<br>0: 100 kΩ<br>1: 75 kΩ<br>2: 50 kΩ<br>3: 25 kΩ                                                                                                                                                                                                                                                                                                                                                                                  |
| 17:16          | R/W | 0x0     | <b>ADC2_PGA_IN_VCM_CTRL</b><br>ADC2 PGA Common-Mode Voltage Control<br>0: 900mV<br>1: 800mV<br>2: 750mV<br>3: 700mV                                                                                                                                                                                                                                                                                                                                                                                                  |
| 15:13          | /   | /       | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 12:8           | R/W | 0x0     | <b>ADC2_PGA_GAIN_CTRL</b><br>ADC2 PGA gain settings:<br>0x0: 0 dB    0x10: 21 dB<br>0x1: 6 dB    0x11: 22 dB<br>0x2: 6 dB    0x12: 23 dB<br>0x3: 6 dB    0x13: 24 dB<br>0x4: 9 dB    0x14: 25 dB<br>0x5: 10 dB   0x15: 26 dB<br>0x6: 11 dB   0x16: 27 dB<br>0x7: 12 dB   0x17: 28 dB<br>0x8: 13 dB   0x18: 29 dB<br>0x9: 14 dB   0x19: 30 dB<br>0xA: 15 dB   0x1A: 31 dB<br>0xB: 16 dB   0x1B: 32 dB<br>0xC: 17 dB   0x1C: 33 dB<br>0xD: 18 dB   0x1D: 34 dB<br>0xE: 19 dB   0x1E: 35 dB<br>0xF: 20 dB   0x1F: 36 dB |
| 7:6            | R/W | 0x1     | <b>ADC2_IOPAAF</b><br>ADC2 OP AAF Bias Current Select<br>00: 1.50*IOPADC<br>01: 1.75*IOPADC                                                                                                                                                                                                                                                                                                                                                                                                                          |

| Offset: 0x0304 |     |         | Register Name: ADC2_REG                                                                                                                                                               |
|----------------|-----|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | R/W | Default | Description                                                                                                                                                                           |
|                |     |         | 10: 2.00*IOPADC<br>11: 2.25*IOPADC<br>IOPADC is defined by ADC1_REG<15:14> from 1uA to 4uA                                                                                            |
| 5:4            | R/W | 0x1     | ADC2_IOPSDM1<br>ADC2 OP SDM Bias Current Select 1<br>00: 1.50*IOPADC<br>01: 1.75*IOPADC<br>10: 2.00*IOPADC<br>11: 2.25*IOPADC<br>IOPADC is defined by ADC1_REG<15:14> from 1uA to 4uA |
| 3:2            | R/W | 0x1     | ADC2_IOPSDM2<br>ADC2 OP SDM Bias Current Select 2<br>00: 1.50*IOPADC<br>01: 1.75*IOPADC<br>10: 2.00*IOPADC<br>11: 2.25*IOPADC<br>IOPADC is defined by ADC1_REG<15:14> from 1uA to 4uA |
| 1:0            | R/W | 0x1     | ADC2_IOPMIC1<br>ADC2 OP MIC1 Bias Current Select<br>00: 1.50*IOPADC<br>01: 1.75*IOPADC<br>10: 2.00*IOPADC<br>11: 2.25*IOPADC<br>IOPADC is defined by ADC1_REG<15:14> from 1uA to 4uA  |

#### 4.1.6.114 0x0308 ADC3 Analog Control Register (Default Value:0x001C\_0055)

| Offset: 0x0308 |     |         | Register Name: ADC3_REG                                      |
|----------------|-----|---------|--------------------------------------------------------------|
| Bit            | R/W | Default | Description                                                  |
| 31             | R/W | 0x0     | ADC3_EN<br>ADC3 Channel Enable<br>0: Disable<br>1: Enable    |
| 30             | R/W | 0x0     | MIC3_PGA_EN<br>MIC3 PGA Enable<br>0: Disable<br>1: Enable    |
| 29             | R/W | 0x0     | ADC3 Dither Control<br>0: New Dither Off<br>1: New Dither On |
| 28:26          | R/W | 0x0     | /                                                            |

| Offset: 0x0308 |             |         | Register Name: ADC3_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |           |             |           |             |           |             |           |             |           |             |            |             |            |             |            |             |            |             |            |             |
|----------------|-------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-------------|-----------|-------------|-----------|-------------|-----------|-------------|-----------|-------------|------------|-------------|------------|-------------|------------|-------------|------------|-------------|------------|-------------|
| Bit            | R/W         | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |           |             |           |             |           |             |           |             |           |             |            |             |            |             |            |             |            |             |            |             |
| 25:24          | R/W         | 0x0     | <p>DSM_DITHER_LVL<br/>Dither Level Control (Dither level is positive related to the ctrl bits)</p> <p>0: No Level<br/>1: Min Level<br/>2: Middle Level<br/>3: Max Level</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                |           |             |           |             |           |             |           |             |           |             |            |             |            |             |            |             |            |             |            |             |
| 23:22          | R/W         | 0x0     | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |           |             |           |             |           |             |           |             |           |             |            |             |            |             |            |             |            |             |            |             |
| 21:20          | R/W         | 0x1     | <p>ADC3_OUTPUT_CURRENT<br/>ADC3 high gain OP Output Current Select</p> <p>00: 15I<br/>01: 20I<br/>10: 35I<br/>11: 40I<br/>I=7uA</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |           |             |           |             |           |             |           |             |           |             |            |             |            |             |            |             |            |             |            |             |
| 19:18          | R/W         | 0x3     | <p>ADC3_PGA_CTRL_RCM<br/>ADC3 PGA Common Mode Input Impedance Control for MICIN</p> <p>0: 100 kΩ<br/>1: 75 kΩ<br/>2: 50 kΩ<br/>3: 25 kΩ</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |           |             |           |             |           |             |           |             |           |             |            |             |            |             |            |             |            |             |            |             |
| 17:16          | R/W         | 0x0     | <p>ADC3_PGA_IN_VCM_CTRL<br/>ADC3 PGA Common-Mode Voltage Control</p> <p>0: 900mV<br/>1: 800mV<br/>2: 750mV<br/>3: 700mV</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |           |             |           |             |           |             |           |             |           |             |            |             |            |             |            |             |            |             |            |             |
| 15:13          | /           | /       | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |           |             |           |             |           |             |           |             |           |             |            |             |            |             |            |             |            |             |            |             |
| 12:8           | R/W         | 0x0     | <p>ADC3_PGA_GAIN_CTRL<br/>ADC3 PGA gain settings:</p> <table> <tbody> <tr> <td>0x0: 0 dB</td> <td>0x10: 21 dB</td> </tr> <tr> <td>0x1: 6 dB</td> <td>0x11: 22 dB</td> </tr> <tr> <td>0x2: 6 dB</td> <td>0x12: 23 dB</td> </tr> <tr> <td>0x3: 6 dB</td> <td>0x13: 24 dB</td> </tr> <tr> <td>0x4: 9 dB</td> <td>0x14: 25 dB</td> </tr> <tr> <td>0x5: 10 dB</td> <td>0x15: 26 dB</td> </tr> <tr> <td>0x6: 11 dB</td> <td>0x16: 27 dB</td> </tr> <tr> <td>0x7: 12 dB</td> <td>0x17: 28 dB</td> </tr> <tr> <td>0x8: 13 dB</td> <td>0x18: 29 dB</td> </tr> <tr> <td>0x9: 14 dB</td> <td>0x19: 30 dB</td> </tr> </tbody> </table> | 0x0: 0 dB | 0x10: 21 dB | 0x1: 6 dB | 0x11: 22 dB | 0x2: 6 dB | 0x12: 23 dB | 0x3: 6 dB | 0x13: 24 dB | 0x4: 9 dB | 0x14: 25 dB | 0x5: 10 dB | 0x15: 26 dB | 0x6: 11 dB | 0x16: 27 dB | 0x7: 12 dB | 0x17: 28 dB | 0x8: 13 dB | 0x18: 29 dB | 0x9: 14 dB | 0x19: 30 dB |
| 0x0: 0 dB      | 0x10: 21 dB |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |           |             |           |             |           |             |           |             |           |             |            |             |            |             |            |             |            |             |            |             |
| 0x1: 6 dB      | 0x11: 22 dB |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |           |             |           |             |           |             |           |             |           |             |            |             |            |             |            |             |            |             |            |             |
| 0x2: 6 dB      | 0x12: 23 dB |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |           |             |           |             |           |             |           |             |           |             |            |             |            |             |            |             |            |             |            |             |
| 0x3: 6 dB      | 0x13: 24 dB |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |           |             |           |             |           |             |           |             |           |             |            |             |            |             |            |             |            |             |            |             |
| 0x4: 9 dB      | 0x14: 25 dB |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |           |             |           |             |           |             |           |             |           |             |            |             |            |             |            |             |            |             |            |             |
| 0x5: 10 dB     | 0x15: 26 dB |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |           |             |           |             |           |             |           |             |           |             |            |             |            |             |            |             |            |             |            |             |
| 0x6: 11 dB     | 0x16: 27 dB |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |           |             |           |             |           |             |           |             |           |             |            |             |            |             |            |             |            |             |            |             |
| 0x7: 12 dB     | 0x17: 28 dB |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |           |             |           |             |           |             |           |             |           |             |            |             |            |             |            |             |            |             |            |             |
| 0x8: 13 dB     | 0x18: 29 dB |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |           |             |           |             |           |             |           |             |           |             |            |             |            |             |            |             |            |             |            |             |
| 0x9: 14 dB     | 0x19: 30 dB |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |           |             |           |             |           |             |           |             |           |             |            |             |            |             |            |             |            |             |            |             |

| Offset: 0x0308 |     |         | Register Name: ADC3_REG                                                                                                                                                               |
|----------------|-----|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | R/W | Default | Description                                                                                                                                                                           |
|                |     |         | 0xA: 15 dB 0x1A: 31 dB<br>0xB: 16 dB 0x1B: 32 dB<br>0xC: 17 dB 0x1C: 33 dB<br>0xD: 18 dB 0x1D: 34 dB<br>0xE: 19 dB 0x1E: 35 dB<br>0xF: 20 dB 0x1F: 36 dB                              |
| 7:6            | R/W | 0x1     | ADC3_IOPAAF<br>ADC3 OP AAF Bias Current Select<br>00: 1.50*IOPADC<br>01: 1.75*IOPADC<br>10: 2.00*IOPADC<br>11: 2.25*IOPADC<br>IOPADC is defined by ADC1_REG<15:14> from 1uA to 4uA    |
| 5:4            | R/W | 0x1     | ADC3_IOPSDM1<br>ADC3 OP SDM Bias Current Select 1<br>00: 1.50*IOPADC<br>01: 1.75*IOPADC<br>10: 2.00*IOPADC<br>11: 2.25*IOPADC<br>IOPADC is defined by ADC1_REG<15:14> from 1uA to 4uA |
| 3:2            | R/W | 0x1     | ADC3_IOPSDM2<br>ADC3 OP SDM Bias Current Select 2<br>00: 1.50*IOPADC<br>01: 1.75*IOPADC<br>10: 2.00*IOPADC<br>11: 2.25*IOPADC<br>IOPADC is defined by ADC1_REG<15:14> from 1uA to 4uA |
| 1:0            | R/W | 0x1     | ADC3_IOPMIC<br>ADC3 OP MIC Bias Current Select<br>00: 1.50*IOPADC<br>01: 1.75*IOPADC<br>10: 2.00*IOPADC<br>11: 2.25*IOPADC<br>IOPADC is defined by ADC1_REG<15:14> from 1uA to 4uA    |

#### 4.1.6.115 0x0310 DAC Analog Control Register (Default Value:0x0455\_0100)

| Offset: 0x0310 |     |         | Register Name: DAC_REG                                                      |
|----------------|-----|---------|-----------------------------------------------------------------------------|
| Bit            | R/W | Default | Description                                                                 |
| 31             | R/W | 0x0     | CURRENT_TEST_SELECT<br>Internal Current Sink Test Enable (from MICIN3P pin) |

| Offset: 0x0310 |     |         | Register Name: DAC_REG                                                                                                       |
|----------------|-----|---------|------------------------------------------------------------------------------------------------------------------------------|
| Bit            | R/W | Default | Description                                                                                                                  |
|                |     |         | 0: Normal<br>1: For Debug                                                                                                    |
| 30:28          | R/W | 0x0     | HEADPHONE_GAIN<br>000: -0dB<br>001: -6dB<br>010: -12dB<br>011: -18dB<br>100: -24dB<br>101: -30dB<br>110: -36dB<br>111: -42dB |
| 27:26          | R/W | 0x1     | IOPHPDRV<br>HPDRVLR OP Bias Current Select<br>00: 6uA<br>01: 7uA<br>10: 8uA<br>11: 9uA                                       |
| 25:24          | R/W | 0x0     | CPLDO_VOLTAGE<br>00: 0.9V<br>01: 1.0V<br>10: 1.1V<br>11: 1.2V                                                                |
| 23:22          | R/W | 0x1     | OPDRV_CUR.<br>OPDRV output stage current setting<br>00: 6uA<br>01: 7uA<br>10: 8uA<br>11: 9uA                                 |
| 21:20          | R/W | 0x1     | IOPVRS<br>VRA2 Buffer OP Bias Current Select<br>00: 6uA<br>01: 7uA<br>10: 8uA<br>11: 9uA                                     |
| 19:18          | R/W | 0x1     | ILINEOUTAMPS<br>LINEOUTLR AMP Bias Current Select<br>00: 6uA<br>01: 7uA<br>10: 8uA<br>11: 9uA                                |
| 17:16          | R/W | 0x1     | IOPDACS                                                                                                                      |

| Offset: 0x0310 |     |         | Register Name: DAC_REG                                                                                             |
|----------------|-----|---------|--------------------------------------------------------------------------------------------------------------------|
| Bit            | R/W | Default | Description                                                                                                        |
|                |     |         | OPDAC Bias Current Select<br>00: 6uA<br>01: 7uA<br>10: 8uA<br>11: 9uA                                              |
| 15             | R/W | 0x0     | DACL_EN<br>DACL Enable<br>0: Disable<br>1: Enable                                                                  |
| 14             | R/W | 0x0     | DACR_EN<br>DACR Enable<br>0: Disable<br>1: Enable                                                                  |
| 13             | R/W | 0x0     | LINEOUTLEN<br>Left Channel LINEOUT Enable<br>0: Disable<br>1: Enable                                               |
| 12             | R/W | 0x0     | LMUTE<br>DACL to Left Channel LINEOUT Mute Control<br>0: Mute<br>1: Not mute                                       |
| 11             | R/W | 0x0     | LINEOUTREN<br>Right Channel LINEOUT Enable<br>0: Disable<br>1: Enable                                              |
| 10             | R/W | 0x0     | RMUTE<br>DACR to Right Channel LINEOUT Mute Control<br>0: Mute<br>1: Not mute                                      |
| 9:8            | R/W | 0x1     | ICPLDO<br>CPLDO Bias Current Select<br>00: 6uA<br>01: 7uA<br>10: 8uA<br>11: 9uA                                    |
| 7              | R/W | 0x0     | CPLDO_ENABLE<br>0: Disable<br>1: Enable                                                                            |
| 6:5            | R/W | 0x0     | /                                                                                                                  |
| 4:0            | R/W | 0x0     | LINEOUT Volume Control, Total 30 level from 0x1F to 0x02<br>with the volume 0dB to -43.5dB, -1.5dB/step, mute when |

| Offset: 0x0310 |     |         | Register Name: DAC_REG |
|----------------|-----|---------|------------------------|
| Bit            | R/W | Default | Description            |
|                |     |         | 00000 & 00001.         |

#### 4.1.6.116 0x0314 DAC2 Analog Control Register (Default Value:0x0000\_0000)

| Offset: 0x0314 |     |         | Register Name: DAC2_REG                                                                                                                                           |
|----------------|-----|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | R/W | Default | Description                                                                                                                                                       |
| 31:18          | R/W | 0x0     | /                                                                                                                                                                 |
| 17:16          | R/W | 0x0     | CKDAC_DELAY_SET<br>clock delay time after CKDAC<br>0: min<br>3: max                                                                                               |
| 15             | R/W | 0x0     | DACL/R_CHOPPER_ENABLE<br>DACL/R chopper enable<br>0: chopper disable<br>1: chopper enable                                                                         |
| 14             | R/W | 0x0     | DACL/R_CHOPPER_NOL_ENABLE<br>DACL/R chopper non-overlapping clock enable<br>0: chopper non-overlapping clock disabled<br>1: chopper non-overlapping clock enabled |
| 13:12          | R/W | 0x0     | DACL/R_CHOPPER_CKSET<br>DACL/R chopper clock frequency<br>Fs:6.144MHz<br>0: 96 kHz<br>1: 192 kHz<br>2: 384 kHz<br>3: 768 kHz                                      |
| 11:10          | R/W | 0x0     | DACL/R_CHOPPER_DELAY_SET<br>Control DACL/R chopper clock delay time after CKDAC<br>0: Min<br>3: Max                                                               |
| 9:8            | R/W | 0x0     | DACL/R_CHOPPER_NOL_DELAY_SET<br>Control DACL/R chopper clock non-overlapping time<br>0: Min when DAC_CHOPPER_NOL_ENABLE=1<br>3: Max when DAC_CHOPPER_NOL_ENABLE=1 |
| 7              | R/W | 0x0     | LINEOUTL/R_CHOPPER_ENABLE<br>LINEOUTL/R chopper enable<br>0: chopper disable<br>1: chopper enable                                                                 |
| 6              | R/W | 0x0     | LINEOUTL/R_CHOPPER_NOL_ENABLE<br>LINEOUTL/R chopper non-overlapping clock enable<br>0: chopper non-overlapping clock disabled                                     |

| Offset: 0x0314 |     |         | Register Name: DAC2_REG                                                                                                                                                                                          |
|----------------|-----|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | R/W | Default | Description                                                                                                                                                                                                      |
|                |     |         | 1: chopper non-overlapping clock enabled                                                                                                                                                                         |
| 5:4            | R/W | 0x0     | <p>LINEOUTL/R_CHOPPER_CKSET<br/>         LINEOUTL/R chopper clock frequency<br/>         Fs:6.144MHz</p> <p>0: 96kHz<br/>         1: 192kHz<br/>         2: 384kHz<br/>         3: 768kHz</p>                    |
| 3:2            | R/W | 0x0     | <p>LINEOUTL/R_CHOPPER_DELAY_SET<br/>         Control LINEOUTL/R chopper clock delay time after<br/>         CKDAC</p> <p>0: Min<br/>         3: Max</p>                                                          |
| 1:0            | R/W | 0x0     | <p>LINEOUTL/R_CHOPPER_NOL_DELAY_SET<br/>         Control LINEOUTL/R chopper clock non-overlapping time</p> <p>0: Min when LINEOUT_CHOPPER_NOL_ENABLE=1<br/>         3: Max when LINEOUT_CHOPPER_NOL_ENABLE=1</p> |

#### 4.1.6.117 0x0318 MICBIAS Analog Control Register (Default Value:0x4000\_3030)

| Offset: 0x0318 |     |         | Register Name: MICBIAS_REG                                                                                                                                                |
|----------------|-----|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | R/W | Default | Description                                                                                                                                                               |
| 31             | R/W | 0x0     | /                                                                                                                                                                         |
| 30:28          | R/W | 0x4     | <p>SELDETADCFS<br/>         Select sample interval of the ADC sample</p> <p>000: 2ms<br/>         ...<br/>         100: 32ms<br/>         ...<br/>         111: 256ms</p> |
| 27:26          | R/W | 0x0     | <p>SELDETADCDB<br/>         Select debounce time when jack removal</p> <p>00: 128ms<br/>         01: 256ms<br/>         10: 512ms<br/>         11: 1024ms</p>             |
| 25:24          | R/W | 0x0     | <p>SELDETADCBF<br/>         Select the time to enable HBIAS before MICADC work</p> <p>00: 2ms<br/>         01: 4ms<br/>         10: 8ms</p>                               |

| Offset: 0x0318 |     |         | Register Name: MICBIAS_REG                                                                                                     |
|----------------|-----|---------|--------------------------------------------------------------------------------------------------------------------------------|
| Bit            | R/W | Default | Description                                                                                                                    |
|                |     |         | 11: 16ms                                                                                                                       |
| 23             | R/W | 0x0     | JACKDETEN<br>Jack detect enable<br>0: Disable<br>1: Enable                                                                     |
| 22:21          | R/W | 0x0     | SELDETADC DY<br>Select the delay time to pull low the MICDET when jack removal<br>00: 0.5ms<br>01: 1ms<br>10: 1.5ms<br>11: 2ms |
| 20             | R/W | 0x0     | MICADCEN<br>Microphone detect ADC enable<br>0: Disable<br>1: Enable                                                            |
| 19             | R/W | 0x0     | POPFREE<br>When this bit is 0, HBIAS MICADC is controlled by register                                                          |
| 18             | R/W | 0x0     | Det Mode<br>0: Jack in pull low<br>1: Jack in pull high                                                                        |
| 17             | R/W | 0x0     | AUTOPLEN<br>Enable the function to auto pull low MICDET when jack removal<br>0: Disable<br>1: Enable                           |
| 16             | R/W | 0x0     | MICDETPL<br>When this bit is 1 and AUTOPLEN is 0, the MICDET is pull to GND                                                    |
| 15             | R/W | 0x0     | HMICBIASEN<br>Headphone Microphone Bias Enable<br>0: Disable<br>1: Enable                                                      |
| 14:13          | R/W | 0x1     | HBIASSEL<br>HMICBIAS Voltage Level Select<br>00: 1.88V<br>01: 2.09V<br>10: 2.33V<br>11: 2.55V                                  |
| 12             | R/W | 0x1     | HMIC BIAS chopper enable<br>0: Disable                                                                                         |

| Offset: 0x0318 |     |         | Register Name: MICBIAS_REG                                                                    |
|----------------|-----|---------|-----------------------------------------------------------------------------------------------|
| Bit            | R/W | Default | Description                                                                                   |
|                |     |         | 1: Enable                                                                                     |
| 11:10          | R/W | 0x0     | HMIC BIAS chopper clock select<br>00: 250 kHz<br>01: 500 kHz<br>10: 1MHz<br>11: 2MHz          |
| 9:8            | R/W | 0x0     | /                                                                                             |
| 7              | R/W | 0x0     | MMICBIASEN<br>Master Microphone Bias Enable<br>0: Disable<br>1: Enable                        |
| 6:5            | R/W | 0x1     | MBIASSEL<br>MMICBIAS Voltage Level Select<br>00: 1.88V<br>01: 2.09V<br>10: 2.33V<br>11: 2.50V |
| 4              | R/W | 0x1     | MMIC BIAS chopper enable<br>0: Disable<br>1: Enable                                           |
| 3:2            | R/W | 0x0     | MMIC BIAS chopper clock select<br>00: 250 kHz<br>01: 500 kHz<br>10: 1MHz<br>11: 2MHz          |
| 1:0            | R/W | 0x0     | /                                                                                             |

#### 4.1.6.118 0x031C Ramp Control Register (Default Value:0x0018\_0000)

| Offset: 0x031C |       |         | Register Name: RAMP_REG                                                                                                                                                           |
|----------------|-------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | R/W   | Default | Description                                                                                                                                                                       |
| 31             | R/W   | 0x0     | RAMP RISE INT En<br>0: Enable<br>1:Disable                                                                                                                                        |
| 30             | R/W1C | 0x0     | RAMP RISE INT<br>RK Increase Upward Finish and Rampen Pull Down<br>Instruction<br>0: No Pending IRQ<br>1: Ramp Rise Finish Pending Interrupt<br>Write '1' to clear this interrupt |
| 29             | R/W   | 0x0     | RAMP FALL INT EN                                                                                                                                                                  |

| Offset: 0x031C |       |         | Register Name: RAMP_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|----------------|-------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | R/W   | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                |       |         | 0: Enable<br>1:Disable                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 28             | R/W1C | 0x0     | RAMP FALL INT<br>RK Downward Decrease Finish and Rampen Pull Down Instruction<br>0: No Pending IRQ<br>1: Ramp Fall Finish Pending Interrupt<br>Write '1' to clear this interrupt                                                                                                                                                                                                                                                                                             |
| 27:25          | /     | /       | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 24             | R/W   | 0x0     | RAMP SOFT RESET<br>0: Disable<br>1:Enable                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 23:21          | /     | /       | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 20:16          | R/W   | 0x18    | RAMP_CLK_DIV_M<br>Analog Ramp Clk Div Freq Value: M (from 0 to 31,<br>Default:24).<br>Ana_Ramp_Clk= 24MHz/(M+1)<br>Default Ramp Clk Freq: 24MHz/(24+1)=960 kHz                                                                                                                                                                                                                                                                                                               |
| 15             | R/W   | 0x0     | HP PULL OUT EN<br>0: Disable<br>1:Enable                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 14:12          | R/W   | 0x0     | RAMP HOLD STEP<br>000: 9600<br>001: 19200<br>010: 38400<br>011: 76800<br>100: 96000<br>101: 115200<br>110: 153600<br>111: 192000<br><br>Ramp Hold Time = Ramp Hold Step/Ramp Clk Freq<br>When Ramp Clk Freq equal to 960 kHz, Corresponding<br>Ramp Hold time of each gear:<br>000: 9600/960 kHz=10ms<br>001: 19200/960 kHz=20ms<br>010: 38400/960 kHz=40ms<br>011: 76800/960 kHz=80ms<br>100: 96000/960 kHz=100ms<br>101: 115200/960 kHz=120ms<br>110: 153600/960 kHz=160ms |

| Offset: 0x031C |     |         | Register Name: RAMP_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|----------------|-----|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | R/W | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                |     |         | 111: 192000/960 kHz=200ms                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 11:10          | /   | /       | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 9:8            | R/W | 0x0     | <p>GAP STEP</p> <p>00: ramp step</p> <p>01: ramp step*2</p> <p>10: ramp step*3</p> <p>11: ramp step*4</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 7              | /   | /       | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 6:4            | R/W | 0x0     | <p>RAMP STEP</p> <p>RK Frequency Gear, Control Ramp Rise/Fall Total Time</p> <p>000: 20</p> <p>001: 30</p> <p>010: 40</p> <p>011: 60</p> <p>100: 80</p> <p>101: 120</p> <p>110: 160</p> <p>111: 240</p> <p>Ramp Rise/Fall Total Time = (Ramp Step/Ramp Clk Freq) *4096</p> <p>When Default Ramp Clk Freq equal to 960 kHz,<br/>Corresponding time of each gear:</p> <p>000: (20/960 kHz) *4096=85.3ms</p> <p>001: (30/960 kHz) *4096=128ms</p> <p>010: (40/960 kHz) *4096=170.6ms</p> <p>011: (60/960 kHz) *4096=256ms</p> <p>100: (80/960 kHz) *4096=341.3ms</p> <p>101: (120/960 kHz) *4096=512ms</p> <p>110: (160/960 kHz) *4096=682.6ms</p> <p>111: (240/960 kHz)*4096=1024ms</p> |
| 3              | R/W | 0x0     | <p>RMD_EN</p> <p>Ramp Manual Down Enable</p> <p>0: Disable</p> <p>1: Enable</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 2              | R/W | 0x0     | <p>RMU_EN</p> <p>Ramp Manual Up Enable</p> <p>0: Disable</p> <p>1: Enable</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 1              | R/W | 0x0     | <p>RMC_EN</p> <p>Ramp Manual Control Enable</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

| Offset: 0x031C |     |         | Register Name: RAMP_REG                                         |
|----------------|-----|---------|-----------------------------------------------------------------|
| Bit            | R/W | Default | Description                                                     |
|                |     |         | 0: Disable, and there is no signal output for DAC.<br>1: Enable |
| 0              | R/W | 0x0     | RD_EN<br>Ramp Digital Enable<br>0: Disable<br>1: Enable         |

#### 4.1.6.119 0x0320 BIAS Analog Control Register (Default Value:0x0000\_0080)

| Offset: 0x0320 |     |         | Register Name: BIAS_REG                                                                                                                                    |
|----------------|-----|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | R/W | Default | Description                                                                                                                                                |
| 31:8           | R/W | 0x0     | /                                                                                                                                                          |
| 7:0            | R/W | 0x80    | BIASDATA<br>Bias Current Register Setting Data<br>This 8-bit register is not controlled by the AUDIO CODEC reset, only controlled by the system bus reset. |

#### 4.1.6.120 0x0324 HEADPHONE Analog Control Register (Default Value:0x8080\_0C44)

| Offset: 0x0324 |     |         | Register Name: HP_REG                                                                 |
|----------------|-----|---------|---------------------------------------------------------------------------------------|
| Bit            | R/W | Default | Description                                                                           |
| 31:24          | R/W | 0x80    | HPRCALVERIFY<br>Right Headphone calibration Setting Data                              |
| 23:16          | R/W | 0x80    | HPLCALVERIFY<br>Left Headphone calibration Setting Data                               |
| 15             | R/W | 0x0     | HPPA_EN<br>Right & Left Headphone PA Enable<br>0: Disable; 1: Enable                  |
| 14:12          | R/W | 0x0     | /                                                                                     |
| 11             | R/W | 0x1     | HPINPUTENABLE<br>When this bit is write to 0, the input stage of headphone disabled   |
| 10             | R/W | 0x1     | HPOUTPUTENABLE<br>When this bit is write to 0, the output stage of headphone disabled |
| 9:8            | R/W | 0x0     | HPPA_DEL<br>Headphone delay time when start up<br>00: 4ms<br>01: 8ms<br>10: 16ms      |

| Offset: 0x0324 |     |         | Register Name: HP_REG                                                                                                   |
|----------------|-----|---------|-------------------------------------------------------------------------------------------------------------------------|
| Bit            | R/W | Default | Description                                                                                                             |
|                |     |         | 11: 32ms                                                                                                                |
| 7:6            | R/W | 0x1     | <p>CP_CLKS<br/>Charge Pump Clock select<br/>00: 250k<br/>01: 330k<br/>10: 660k<br/>11: 1000k</p>                        |
| 5              | R/W | 0x0     | <p>HPCALIMODE<br/>HEADPHONE calibration equilibration MODE select<br/>0: equilibration mode<br/>1: no equilibration</p> |
| 4              | R/W | 0x0     | <p>HPCALIVERIFY<br/>HEADPHONE calibration in verify mode enable<br/>0: Disable; 1: Enable</p>                           |
| 3              | R/W | 0x0     | <p>HPCALIFIRST<br/>When this bit is write to 1 , HEADPHONE Calibration once before enable</p>                           |
| 2:0            | R/W | 0x4     | <p>HPCALICKS<br/>HEADPHONE Calibration clock frequency select<br/>000: 4<br/>...<br/>100: 64<br/>...<br/>111: 512</p>   |

#### 4.1.6.121 0x0328 HMIC Control Register (Default Value: 0x0000\_0008)

| Offset: 0x0328 |     |         | Register Name: HMIC_CTRL                                                                                                                                                                                                     |
|----------------|-----|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | R/W | Default | Description                                                                                                                                                                                                                  |
| 31:23          | /   | /       | /                                                                                                                                                                                                                            |
| 22:21          | R/W | 0x0     | <p>HMIC_SAMPLE_SELECT<br/>Down Sample Setting Select<br/>00: Down by 1, 128Hz<br/>01: Down by 2, 64Hz<br/>10: Down by 4, 32Hz<br/>11 : Down by 8, 16Hz</p>                                                                   |
| 20:16          | R/W | 0x0     | <p>MDATA_Threshold<br/>The threshold of MIC_DET pending<br/>When HMIC_M is not set, and the deviation between the current obtained value and the threshold exceeds MDATA_Threshold_Debounce at twice time, the interrupt</p> |

| Offset: 0x0328 |     |         | Register Name: HMIC_CTRL                                                                                                                                                                                                                        |
|----------------|-----|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | R/W | Default | Description                                                                                                                                                                                                                                     |
|                |     |         | is pending.                                                                                                                                                                                                                                     |
| 15:14          | R/W | 0x0     | <b>HMIC_SF</b><br>HMIC Smooth Filter setting<br>The compare value of MIC interrupt is the value after Smooth Filter.<br>00: by pass<br>01: $(x_1+x_2)/2$<br>10: $(x_1+x_2+x_3+x_4)/4$<br>11: $(x_1+x_2+x_3+x_4+x_5+x_6+x_7+x_8)/8$              |
| 13:10          | R/W | 0x0     | <b>HMIC_M</b><br>Debounce when the MIC Key down or up.<br>0000:1 samlpe data<br>0001:2 samlpe data<br>...<br>1111:16 samlpe data                                                                                                                |
| 9:6            | R/W | 0X0     | <b>HMIC_N</b><br>Debounce when earphone plug in or pull out<br>125ms-2s<br>0000:125ms<br>0001:250ms<br>...<br>1111:2s                                                                                                                           |
| 5:3            | R/W | 0x1     | <b>MDATA_Threshold_Debounce</b><br>000:0<br>001:1<br>010:2<br>011:3<br>100:4<br>101:5<br>110:6<br>111:7<br>11: Reserve (default 1)<br>When a MDATA value is added, if the variation is beyond this threshold, the MIC interrupt will be pending |
| 2              | R/W | 0x0     | <b>JACK_OUT_IRQ_EN</b><br>MIC Detect Interrupt Set<br>0: disable<br>1 : enable                                                                                                                                                                  |
| 1              | R/W | 0x0     | <b>JACK_IN_IRQ_EN</b><br>MIC Detect Interrupt Set<br>0: disable                                                                                                                                                                                 |

| Offset: 0x0328 |     |         | Register Name: HMIC_CTRL                                             |
|----------------|-----|---------|----------------------------------------------------------------------|
| Bit            | R/W | Default | Description                                                          |
|                |     |         | 1 : enable                                                           |
| 0              | R/W | 0x0     | MIC_DET_IRQ_EN<br>MIC Detect Interrupt Set<br>0: Disable<br>1:Enable |

#### 4.1.6.122 0x032C HMIC Status Register (Default Value: 0x0000\_6000)

| Offset: 0x032C |       |         | Register Name: HMIC_STS                                                                                                                                                                                             |
|----------------|-------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | R/W   | Default | Description                                                                                                                                                                                                         |
| 31:15          | /     | /       | /                                                                                                                                                                                                                   |
| 14:13          | R/W   | 0x3     | MDATA_DISCARD<br>After MIC DATA data receiving, the first N-data will be discarded. N defined as follows:<br>00: 0; None discarded<br>01: 1; 1-data discarded<br>10: 2; 2-data discarded<br>11: 4; 4-data discarded |
| 12:8           | R     | 0x0     | HMIC_DATA<br>HMIC Average Data                                                                                                                                                                                      |
| 7:5            | /     | /       | /                                                                                                                                                                                                                   |
| 4              | R/W1C | 0x0     | JACK_DET_OIRQ<br>Jack output detect Pending interrupt<br>0: No Pending IRQ<br>1: Pending IRQ<br>Writing 1 clear pending                                                                                             |
| 3              | R/W1C | 0x0     | JACK_DET_IIRQ<br>Jack input detect pending interrupt<br>0: No Pending IRQ<br>1: Pending IRQ<br>Writing 1 clear pending                                                                                              |
| 2:1            | /     | /       | /                                                                                                                                                                                                                   |
| 0              | R/W1C | 0x0     | MIC_DET_ST.<br>MIC Detect Pending interrupt<br>0: No pending IRQ<br>1: Pending IRQ<br>Writing 1 clear pending                                                                                                       |

## 4.1.6.123 0x0348 POWER Analog Control Register (Default Value:0x8800\_3711)

| Offset: 0x0348 |     |         | Register Name: POWER_REG                                                                                                                                                                                                                                                                                                                    |
|----------------|-----|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | R/W | Default | Description                                                                                                                                                                                                                                                                                                                                 |
| 31             | R/W | 0x1     | ALDO_EN<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                                                                                          |
| 30             | R/W | 0x0     | /                                                                                                                                                                                                                                                                                                                                           |
| 29             | R/W | 0x0     | VAR1SPEEDUP_DOWN_Further_CTRL<br>VRA1Speedup Down Further Control in AUDIO CODEC<br>Analog<br>0: Digital Signal Interface Pin l_vra1speedup<br>(vra1_speedup_down) Normally Control VRA1 Speedup<br>down<br>1: Manual Control Finish VRA1 Speedup down, Ignore<br>Digital Signal Interface Pin l_vra1speedup<br>(vra1_speedup_down) Control |
| 28             | R/W | 0x0     | /                                                                                                                                                                                                                                                                                                                                           |
| 27             | R/W | 0x1     | LDO for VRP Chopper Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                                                                       |
| 26:25          | R/W | 0x0     | LDO for VRP chopper clock select<br>00: 250 kHz<br>01: 500 kHz<br>10: 1MHz<br>11: 2MHz                                                                                                                                                                                                                                                      |
| 24             | R/W | 0x0     | VRP_LDO_EN<br>LDO for VRP Enable Control<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                                                         |
| 23:17          | R/W | 0x0     | /                                                                                                                                                                                                                                                                                                                                           |
| 16             | R   | 0x0     | AVCCPOR<br>AVCCPOR Monitor                                                                                                                                                                                                                                                                                                                  |
| 15             | R/W | 0x0     | BG_BUFFER_DISABLE<br>0: Enable<br>1: Disable                                                                                                                                                                                                                                                                                                |
| 14:12          | R/W | 0x3     | ALDO_OUTPUT_VOLTAGE<br>ALDO Output Voltage Control<br>0: 2.03 V 4: 1.73 V<br>1: 1.95 V 5: 1.67 V<br>2: 1.87 V 6: 1.61 V<br>3: 1.80 V 7: 1.56V<br>When the BG output voltage is 0.9V, the voltages above                                                                                                                                     |

| Offset: 0x0348 |     |         | Register Name: POWER_REG                                                                                                                                                                                                                                                           |
|----------------|-----|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | R/W | Default | Description                                                                                                                                                                                                                                                                        |
|                |     |         | are the values of this bit. When the BG output voltage is not 0.9V, it is needed to convert the above voltages according to the corresponding ratio to get the actual ALDO ouput voltages.                                                                                         |
| 11:8           | R/W | 0x7     | BG_ROUGH_TRIM<br>BG Output ROUGH Voltage Rough Trimming<br>Every step is 25 mV.<br>The BG output voltage range is from 710 mV to 1085 mV.<br>The default output voltage is 885 mV.                                                                                                 |
| 7:0            | R/W | 0x11    | BG_FINE_TRIM<br>BG Output Voltage Fine Trimming<br>Only lower 6-bit is used and every step is 0.5 mV.<br>The BG output voltage range is from 0 to 32.5 mV.<br>The default output voltage is 15 mV.<br><b>Note: This register is only controlled by system bus clock and reset.</b> |

## 4.2 I2S/PCM

### 4.2.1 Overview

The I2S/PCM controller is designed to transfer streaming audio-data between the system memory and the codec chip. The controller supports standard I2S format, Left-justified mode format, Right-justified mode format, PCM mode format, and TDM mode format.

The I2S/PCM controller includes the following features:

- Four I2S/PCM external interfaces (I2S0, I2S1, I2S2, and I2S3) for connecting external power amplifier and MIC ADC
- Compliant with standard Philips Inter-IC sound (I2S) bus specification
  - Left-justified, Right-justified, PCM mode, and Time Division Multiplexing (TDM) format
  - Programmable PCM frame width: 1 BCLK width (short frame) and 2 BCLKs width (long frame)
- FIFOs for transmitting and receiving data
  - Programmable FIFO thresholds
  - 128 depth x 32-bit width TXFIFO and 64 depth x 32-bit width RXFIFO
- Supports multiple function clocks
  - Clock up to 24.576 MHz Data Output of I2S/PCM in Master mode (Only if the IO PAD and Peripheral I2S/PCM satisfy Timing Parameters)
  - Clock up to 12.288 MHz Data Input of I2S/PCM in Master mode
- Supports TX/RX DMA slave interface
- Supports multiple application scenarios
  - Up to 16 channels ( $f_s = 48 \text{ kHz}$ ) which has adjustable width from 8-bit to 32-bit
  - Sample rate from 8 kHz to 384 kHz (sample rate \* channel \* slot width  $\leq 24.576 \text{ MHz}$ )
  - 8-bit u-law and 8-bit A-law companded sample
- Supports master/slave mode

#### 4.2.2 Block Diagram

The following figure shows the functional block diagram of the I2S/PCM interface.

**Figure 4-14 I2S/PCM Interface System Block Diagram**



The following figure shows the typical application of the I2S/PCM interface.

**Figure 4-15 Typical Application of I2S/PCM Interface**



The I2S/PCM interface system integrates one I2S\_TX and one I2S\_RX.

- The I2S\_TX is for playing music in I2S or PCM format.
- The I2S\_RX is for receiving data in I2S or PCM format.
- When the I2S works in the master mode, the external I2S module provides **BCLK\_in** and **LRCK\_in** for the clock management unit (CMU), and the I2S\_TX and I2S\_RX work with the two external clocks.
- When the I2S works in the slave mode, the CMU provides clocks **BCLK\_out** and **LRCK\_out** for the external I2S module, and the I2S\_TX and I2S\_RX work with the internal clocks.

## 4.2.3 Functional Description

### 4.2.3.1 External Signals

The following table describes the external signals of the I2S/PCM interface.

LRCK and BCLK are bidirectional I/O. When the I2S/PCM interface works in the Master mode, LRCK and BCLK are output pins. When the I2S/PCM interface works in the Slave mode, LRCK and BCLK are input pins.

MCLK is an output pin for external devices. DOUT are the serial data output pins and DIN are the serial data input pins. For details about General Purpose I/O port, refer to section 8.5 GPIO.

**Table 4-2 I2S/PCM External Signals**

| Signal Name    | Description                                | Type |
|----------------|--------------------------------------------|------|
| I2S0-DOUT[3:0] | I2S0/PCM0 Serial Data Output Channel [3:0] | O    |
| I2S0-DIN[3:0]  | I2S0/PCM0 Serial Data Input Channel [3:0]  | I    |
| I2S0-MCLK      | I2S0 Master Clock                          | O    |
| I2S0-LRCK      | I2S0/PCM0 Sample Rate Clock/Sync           | I/O  |
| I2S0-BCLK      | I2S0/PCM0 Bit Rate Clock                   | I/O  |
| I2S1-DOUT[1:0] | I2S1/PCM1 Serial Data Output Channel [1:0] | O    |
| I2S1-DIN[1:0]  | I2S1/PCM1 Serial Data Input Channel [1:0]  | I    |
| I2S1-MCLK      | I2S1 Master Clock                          | O    |
| I2S1-LRCK      | I2S1/PCM01 Sample Rate Clock/Sync          | I/O  |
| I2S1-BCLK      | I2S1/PCM1 Bit Rate Clock                   | I/O  |
| I2S2-DOUT[3:0] | I2S2/PCM2 Serial Data Output Channel [3:0] | O    |
| I2S2-DIN[3:0]  | I2S2/PCM2 Serial Data Input Channel [3:0]  | I    |
| I2S2-MCLK      | I2S2 Master Clock                          | O    |
| I2S2-LRCK      | I2S2/PCM2 Sample Rate Clock/Sync           | I/O  |
| I2S2-BCLK      | I2S2/PCM2 Bit Rate Clock                   | I/O  |
| I2S3-DOUT[3:0] | I2S3/PCM3 Serial Data Output Channel [3:0] | O    |
| I2S3-DIN[3:0]  | I2S3/PCM3 Serial Data Input Channel [3:0]  | I    |
| I2S3-MCLK      | I2S3 Master Clock                          | O    |
| I2S3-LRCK      | I2S3/PCM3 Sample Rate Clock/Sync           | I/O  |
| I2S3-BCLK      | I2S3/PCM3 Bit Rate Clock                   | I/O  |

### 4.2.3.2 Clock Sources

The following table describes the clock sources for I2S/PCM. For clock setting, configurations, and gating information, refer to section 2.11 Power Reset Clock Management (PRCM).

**Table 4-3 I2S/PCM Clock Sources**

| Clock Source  | Description                               | Module |
|---------------|-------------------------------------------|--------|
| PLL_AUDIO(4x) | By default, PLL_AUDIO(4X) is 98.2856 MHz. | CCU    |

| Clock Source      | Description                                                                                                            | Module |
|-------------------|------------------------------------------------------------------------------------------------------------------------|--------|
| PLL_AUDIO1 (DIV2) | By default, PLL_AUDIO1 is 3072 MHz, PLL_AUDIO1 (DIV2) is 1536 MHz, and PLL_AUDIO1 (DIV5) is 614.4 MHz (24.576 MHz*25). |        |
| PLL_AUDIO1 (DIV5) |                                                                                                                        | PRCM   |

#### 4.2.3.3 Timing Diagram

The I2S/PCM supports standard I2S mode, Left-justified I2S mode, Right-justified I2S mode, PCM mode, and TDM mode. The software can select the modes by setting [I2S/PCM\\_CTL](#). The following figures describe the waveforms for SYNC, BCLK, DOUT, and DIN in different modes.

Each sampling period contains an LRCK. The low level of LRCK is the left channel corresponding to the even slots, and the high level is the right channel corresponding to the odd slots. Each slot is the sampling point of a mono channel. The sampling period can support the transmission of 2/4/8/16 slots. The BCLK corresponds to the serial data bit.

**Figure 4-16 I2S Standard Mode Timing**



**Figure 4-17 Left-Justified Mode Timing**



Figure 4-18 Right-Justified Mode Timing



Figure 4-19 PCM Long Frame Mode Timing



Figure 4-20 PCM Short Frame Mode Timing (one BCLK cycle)



#### 4.2.3.4 ASRC

The ASRC module supports sampling rate conversion between the up-sampling and down-sampling. The ASRC also supports sampling rate conversion between dual-channel audio data, and the size of the sampling data is up to 24 bits.

The ASRC module has the following features:

- Typical THD + N: -130 dB (Range: -125 dB to -139 dB)
- Supports sampling rate conversion between the up-sampling and down-sampling to implement the sampling rate conversion for stereo data
  - The up-sampling ratio ranges from 1 to 7.5x
  - The down-sampling ratio ranges from 8 to 1x
- Supports sampling rate conversion between two identical frequencies
- Sampling rate for both the input and output range is from 8 kHz to 192 kHz and can be decimal
- Sampling rate can be configured manually or via adaptive generation
- The ASRC input is connected to I2S RX\_FIFO\_WDATA [31:8], and the input data is 24-bit MSB big-endian. For the input data that is less than 24 bits, use zeros to pad out the values at the low bits instead of high bits
- The ASRC needs some time to calculate the result. The output outsamplea/b will keep 0 during the calculation, and then change to the valid value when the result comes out

#### Calculating the ASRC Latency

Calculate the ASRC up-sampling and down-sampling latency according to the following formulas.

$$\text{Upsampling Latency} = \text{Phase Delay} + \text{FIFO Delay} = 32 + 16 = 48 \text{ Input Sample Periods}$$

$$\text{Downsampling Latency} = \text{Phase Delay} + \text{FIFO Delay} = (32 * f_{\text{out}}/f_{\text{in}}) + 16 \text{ Input Sample Periods}$$

#### ASRC Timing

The MCLK samples the input clock CLKIN to generate pulse signals.

The following figure shows the timing requirements for the inputs.

**Figure 4-21 Timing Requirements for Inputs**



The following figure shows the timing requirements for the outputs.

**Figure 4-22 Timing Requirements for Outputs**



For the up-sampling,  $F_{MCLK} = F_{sout} * 1350$

For the down-sampling,  $F_{MCLK} = F_{sin} * 0.30 + F_{sout} * 295$

The following table provides the proper values of MCLK in MHz with different  $F_{sin}$  and  $F_{sout}$  in kHz.

**Table 4-4 Proper MCLK Values with Different  $F_{sin}$  and  $F_{sout}$**

| $F_{sin}$ \ $F_{sout}$ | 32  | 44.1 | 48  | 88.2 | 96  | 144 | 192 |
|------------------------|-----|------|-----|------|-----|-----|-----|
| 32                     | 45  | 60   | 65  | 120  | 130 | 195 | 260 |
| 44.1                   | 55  | 60   | 65  | 120  | 130 | 195 | 260 |
| 48                     | 60  | 65   | 65  | 120  | 130 | 195 | 260 |
| 88.2                   | 105 | 105  | 110 | 120  | 130 | 195 | 260 |
| 96                     | 110 | 115  | 115 | 125  | 130 | 195 | 260 |
| 144                    | 160 | 165  | 165 | 175  | 180 | 195 | 260 |
| 192                    | 210 | 215  | 215 | 225  | 230 | 245 | 260 |



The units for  $F_{sin}$  and  $F_{sout}$  are kHz and MCLK is MHz.

#### 4.2.3.5 Operation Modes

The software operation of the I2S/PCM is divided into five steps: system setup, I2S/PCM initialization, the channel setup, DMA setup, and Enable/Disable module.

The following figure shows the whole operation flow of I2S/PCM.

**Figure 4-23 I2S/PCM Operation Flow**



### Step 1 System Setup and I2S/PCM Initialization

The clock source for the I2S/PCM should be followed. Firstly, disable the PLL\_AUDIO through PLL\_AUDIOx Control Register[PLL\_ENABLE] in the CCU or PRCM. Secondly, set up the frequency of the PLL\_AUDIO in the PLL\_AUDIOx Control Register. After that, enable the I2S/PCM gating through the I2S/PCMx\_CLK\_REG when you checkout that the PLL\_AUDIOx Control Register[LOCK] becomes to 1. At last, reset and enable the I2S/PCM bus gating by setting [I2S\\_BGR\\_REG](#).

After the system setup, the register of I2S/PCM can be setup. Firstly, initialize the I2S/PCM. You should close the Globe Enable bit ([I2S/PCM\\_CTL\[0\]](#)), Transmitter Block Enable bit ([I2S/PCM\\_CTL\[2\]](#)), and Receiver Block Enable bit ([I2S/PCM\\_CTL\[1\]](#)) by writing 0. After that, clear the TX/RX FIFO by writing 0 to the bit[25:24] of [I2S/PCM\\_FCTL](#). At last, you can clear the TX FIFO and RX FIFO counter by writing 0 to [I2S/PCM\\_TXCNT](#) and [I2S/PCM\\_RXCNT](#).

### Step 2 Parameter Setup and DMA Setup

First, you can set up the I2S/PCM of master and slave. The configuration can be referred to the protocol of I2S/PCM. Then, you can set up the translation mode, the sample resolution, the width of the slot, the channel slot number, and the trigger level, and so on. The setup of the register can be found in the specification.

The I2S/PCM supports two methods to transfer the data. The most common way is DMA, the setup of DMA can be found in the section 2.6 DMA Controller (DMAC). In this module, you just enable the DRQ.

### Step 3 Enable and Disable I2S/PCM

To enable the function, you can enable TX/RX by writing [I2S/PCM\\_CTL\[TXEN\]](#)/[I2S/PCM\\_CTL\[RXEN\]](#). After that, enable I2S/PCM by writing 1 to [I2S/PCM\\_CTL\[Globe Enable\]](#). Write 0 to the Globe Enable bit to disable I2S/PCM.

## 4.2.4 Programming Guidelines

### 4.2.4.1 Application Example of Processing ASRC Input and Output Data

The following example shows a typical application of ASRC: the input data is 24-bit valid, and the output data is a 32-bit data whose highest 24 bits are valid output and the lowest eight bits are padded out with zeros.

To implement the application, configure the sample resolution and slot width as 32 bits. Follow the steps below:

**Step 1** For the input register: 0x04 [6:4] sample\_res = 3`h7, 0x04 [2:0] slot\_width = 3`h7.

The format of the input data: 32'hXXXXXXXXX, where, bit [31] is the MSB and X is the valid data bit.

**Step 2** For the output register: 0x04 [6:4] sample\_res = 3`h7, 0x04 [2:0] slot\_width = 3`h7

The format of the output data: 32'hXXXXXXXX00, where, bit [31] is the MSB, X is the valid data bit, and bit [7:0] are the padded zeros.

### 4.2.4.2 Converting the Sampling Rate with ASRC

Converting a 48 kHz sampling rate to 16 kHz is the most common scenario in actual applications. Follow the steps below to convert the sampling rate from 48 kHz to 16 kHz for the 32-bit data.

**Step 1** Configure the PLL\_AUDIO Register

- a) Configure [PLL\\_AUDIO\\_CTRL\\_REG](#)[31:0] as 0x8814AB01. That is, PLL\_AUDIO =  $24 * (171+1) / (1+1) / (1+0) / (1+20) = 98.286$  MHz. According to the relationship among the Fsin, Fsout, and MCLK, the MCLK should be greater than 60 MHz. In the simulation phase, the HOSC frequency is 25 MHz, so the output frequency of PLL\_AUDIO should be  $25 * (171+1) / (1+1) / (1+0) / (1+20) = 102.381$  MHz. In the IC test phase, configure the frequency of PLL\_AUDIO according to its actual output frequency.
- b) It is suggested that you configure the ASRC MCLK as an equal-duty-cycle signal. You can specify an odd number for bit[21:16] (PLL\_POST\_DIV\_P) of [PLL\\_AUDIO\\_CTRL\\_REG](#) to get an equal-duty-cycle output clock of PLL\_AUDIO.
- c) Configure bit[25:24] of [I2S3\\_ASRC\\_CLK\\_REG](#) as 0x00 to select the PLL\_AUDIO(4X).

**Step 2** Configure the I2S Registers

- a) Configure bit[7:4] (BCLKDIV) of [I2S/PCM\\_CLKD](#) as 4`h9, that is, the frequency of BCLK will be  $98.286 \text{ MHz} / 32 = 3.072$  MHz.
- b) Configure bit[17:8] (LRCK\_PERIOD) of [I2S/PCM\\_FMT0](#) as 10`h1F. That is, the LRCK\_PERIOD width is configured as 32 BLCKs and can generate the ASRC CLKIN with a 48 kHz sampling rate. ( $\frac{3.072\text{MHz}}{32*2} = 48\text{kHz}$ )

- c) Configure bit[6:4] (Sample Resolution bits) of [I2S/PCM\\_FMT0](#) as 3`h7 to specify the sample resolution as 32-bit.
- d) Configure bit[2:0] (Slot Width bits) of [I2S/PCM\\_FMT0](#) as 3`h7 to specify the slot width as 32-bit.

### Step 3 Configure the ASRC Registers

- a) Configure bit[16] (clock gate) of [MCLKCFG](#) as 1`h1 to open the clock gating.
- b) Configure bit[3:0] (division factor) of [MCLKCFG](#) as 1`h1 to specify the division factor as 1.
- c) Configure bit[20] (clock gate ) of [FsoutCFG](#) as 1`h1 to open the clock gating.
- d) Configure bit[19:16] (clock select) of [FsoutCFG](#) as 4`h0 to select I2S0\_ASRC\_CLK as the clock source.
- e) Configure bit[7:4] (the first division factor) of [FsoutCFG](#) as 16`h13 to configure the first division factor as 128.
- f) Configure bit[3:0] (the second division factor) of [FsoutCFG](#) as 16`h10 to configure the second division factor as 48.
- g) Configure the ASRC ratio.

To configure the ASRC ratio manually, configure bit[31] (Manual Configuration of ASRC Ratio Enable) of [ASRCMANCFG](#) as 1`h1 to enable the manual configuration of ASRC ratio. Configure bit[25:0] of [ASRCMANCFG](#) as 26`h155555 to specify the ratio value as 0x155555. The calculation formula for the ratio value: Dec2Hex (Fsout/Fsin) \*222). In this example, Fsout/Fsin = 16 kHz/48 kHz=1/3, then the ratio is 0x155555.

To configure the ASRC ratio automatically, configure bit[31] (Manual Configuration of ASRC Ratio Enable) of [ASRCMANCFG](#) as 1`h0 to enable the automatic configuration of ASRC ratio. Then the system will automatically calculate the ratio value based on the MCLK, Fsout, and Fsin.

#### 4.2.5 Register List

| Module Name | Base Address | Comments                                      |
|-------------|--------------|-----------------------------------------------|
| I2S PCM0    | 0x07112000   | Use for Speech Input.                         |
| I2S PCM1    | 0x07113000   | I2S PCM1 register is the same with I2S PCM0 . |
| I2S PCM2    | 0x07114000   | I2S PCM2 register is the same with I2S PCM0.  |
| I2S PCM3    | 0x07115000   | I2S PCM3 register is the same with I2S PCM0.  |

| Register Name | Offset | Description               |
|---------------|--------|---------------------------|
| I2S PCM_CTL   | 0x0000 | I2S PCM Control Register  |
| I2S PCM_FMT0  | 0x0004 | I2S PCM Format Register 0 |
| I2S PCM_FMT1  | 0x0008 | I2S PCM Format Register 1 |

| Register Name     | Offset | Description                                       |
|-------------------|--------|---------------------------------------------------|
| I2S PCM_ISTA      | 0x000C | I2S PCM Interrupt Status Register                 |
| I2S PCM_RXFIFO    | 0x0010 | I2S PCM RXFIFO Register                           |
| I2S PCM_FCTL      | 0x0014 | I2S PCM FIFO Control Register                     |
| I2S PCM_FSTA      | 0x0018 | I2S PCM FIFO Status Register                      |
| I2S PCM_INT       | 0x001C | I2S PCM DMA And Interrupt Control Register        |
| I2S PCM_TXFIFO    | 0x0020 | I2S PCM TXFIFO Register                           |
| I2S PCM_CLKD      | 0x0024 | I2S PCM Clock Divide Register                     |
| I2S PCM_TXCNT     | 0x0028 | I2S PCM TX Sample Counter Register                |
| I2S PCM_RXCNT     | 0x002C | I2S PCM RX Sample Counter Register                |
| I2S PCM_CHCFG     | 0x0030 | I2S PCM Channel Configuration Register            |
| I2S PCM_TX0CHSEL  | 0x0034 | I2S PCM TX0 Channel Select Register               |
| I2S PCM_TX1CHSEL  | 0x0038 | I2S PCM TX1 Channel Select Register               |
| I2S PCM_TX2CHSEL  | 0x003C | I2S PCM TX2 Channel Select Register               |
| I2S PCM_TX3CHSEL  | 0x0040 | I2S PCM TX3 Channel Select Register               |
| I2S PCM_TX0CHMAP0 | 0x0044 | I2S PCM TX0 Channel Mapping Register0             |
| I2S PCM_TX0CHMAP1 | 0x0048 | I2S PCM TX0 Channel Mapping Register1             |
| I2S PCM_TX1CHMAP0 | 0x004C | I2S PCM TX1 Channel Mapping Register0             |
| I2S PCM_TX1CHMAP1 | 0x0050 | I2S PCM TX1 Channel Mapping Register1             |
| I2S PCM_TX2CHMAP0 | 0x0054 | I2S PCM TX2 Channel Mapping Register0             |
| I2S PCM_TX2CHMAP1 | 0x0058 | I2S PCM TX2 Channel Mapping Register1             |
| I2S PCM_TX3CHMAP0 | 0x005C | I2S PCM TX3 Channel Mapping Register0             |
| I2S PCM_TX3CHMAP1 | 0x0060 | I2S PCM TX3 Channel Mapping Register1             |
| I2S PCM_RXCHSEL   | 0x0064 | I2S PCM RX Channel Select Register                |
| I2S PCM_RXCHMAP0  | 0x0068 | I2S PCM RX Channel Mapping Register0              |
| I2S PCM_RXCHMAP1  | 0x006C | I2S PCM RX Channel Mapping Register1              |
| I2S PCM_RXCHMAP2  | 0x0070 | I2S PCM RX Channel Mapping Register2              |
| I2S PCM_RXCHMAP3  | 0x0074 | I2S PCM RX Channel Mapping Register3              |
| MCLKCFG           | 0x0080 | I2S PCM ASRC MCLK Configure Register              |
| FsoutCFG          | 0x0084 | I2S PCM ASRC Out Sample Configure Register        |
| FsinEXTCFG        | 0x0088 | I2S PCM In Sample Pluse Extend Configure Register |
| ASRCEN            | 0x008C | I2S PCM ASRC Enable Configure Register            |
| ASRCMANCFG        | 0x0090 | I2S PCM ASRC Manual Configure Register            |
| ASRCRATIOSTAT     | 0x0094 | I2S PCM ASRC Ratio State Configure Register       |
| ASRCFIFOSTAT      | 0x0098 | I2S PCM ASRC FIFO State Configure Register        |
| ASRCMBISTCFG      | 0x009C | I2S PCM ASRC MBIST Test Configure Register        |
| ASRCMBISTSTA      | 0x00A0 | I2S PCM ASRC MBIST Test State Configure Register  |